- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我的情况是我有一个 C++ 类 (MyClass),其方法具有以下签名:
bool getSerialized(const stdString & name, std::string & serialized);
其中 name 是一个 in 参数,serialized 是一个 out 参数。
我通过在“i”文件中进行 %extend 和 %ignore 声明来让它工作,如下所示:
%extend MyClass{
std::string getSerialized(const std::string & name){
std::string res;
$self->getSerialized(name, res);
return res;
};
%rename("$ignore", fullname=1) "MyClass::getSerialized";
因此可以从 Java 中使用该方法,例如:
MyClass mc = new MyClass();
String res = mc.getSerialized("test");
但是现在我遇到了一个问题,序列化后的std::string包含二进制数据,包括'\0'字符表示C字符串的结尾,实际上下面的代码在C++中显示了问题:
std::string s;
s.push_back('H');
s.push_back('o');
s.push_back(0);
s.push_back('l');
s.push_back('a');
std::cout << "Length of std::string " << s.size() << std::endl;
std::cout << "CString: '" << s.c_str() << "'" << std::endl;
上面的代码显示:
Length of std::string 5
CString: 'Ho'
正如我在 SWIG 生成的 wrap 文件中看到的,wrap 方法实际上调用了 c_str(),wrap 代码:
jstring jresult = 0 ;
std::string result;
result = (arg1)->getSerialized();
jresult = jenv->NewStringUTF((&result)->**c_str()**);
return jresult;
因此,正如预期的那样,Java 中接收到的字符串被截断了。那么我该如何更改(大概)我的 %extend 函数包装器,以便我可以将其作为字节数组 (byte[]) 返回,而无需事先知道数组的长度。如果可以在 SWIG 层中创建 byteArray 就好了,这样我就可以从 Java 中调用该方法,例如:
byte[] serialized = mc.getSerialized("test");
其他注意事项:给出了使用 std::string 存储二进制数据,以及使用 Google protobuf 库的返回类型 C++ protobuf usage
有一个非常相似的问题,包括标题Swig: convert return type std::string to java byte[]但是没有二进制数据的情况,所以那里给出的解决方案不适用于这里。
使用 SWIG 2。
最佳答案
您可以使用一些类型映射和一些 JNI 来完成您想做的事情。我举了一个例子:
%module test
%include <std_string.i>
%typemap(jtype) bool foo "byte[]"
%typemap(jstype) bool foo "byte[]"
%typemap(jni) bool foo "jbyteArray"
%typemap(javaout) bool foo { return $jnicall; }
%typemap(in, numinputs=0) std::string& out (std::string temp) "$1=&temp;"
%typemap(argout) std::string& out {
$result = JCALL1(NewByteArray, jenv, $1->size());
JCALL4(SetByteArrayRegion, jenv, $result, 0, $1->size(), (const jbyte*)$1->c_str());
}
// Optional: return NULL if the function returned false
%typemap(out) bool foo {
if (!$1) {
return NULL;
}
}
%inline %{
struct Bar {
bool foo(std::string& out) {
std::string s;
s.push_back('H');
s.push_back('o');
s.push_back(0);
s.push_back('l');
s.push_back('a');
out = s;
return true;
}
};
%}
它声明 C++ 包装器为匹配 bool foo
的函数返回一个 Java 字节数组。它还设置了一个临时的 std::string
以提供 foo
的真正实现,它从 Java 接口(interface)本身隐藏了输入参数。
调用完成后,它会创建并返回一个字节数组,前提是该函数未返回 false。
我检查过它是否按预期工作:
public class run {
public static void main(String[] argv) {
String s = "ho\0la";
System.out.println(s.getBytes().length);
System.loadLibrary("test");
Bar b = new Bar();
byte[] bytes = b.foo();
s = new String(bytes);
System.out.println(s + " - " + s.length());
assert(s.charAt(2) == 0);
}
}
您应该了解从 c_str()
的返回类型转换为 const jbyte*
的含义 - 它可能并不总是您想要的。
作为替代方案,如果输出字节数组的大小实际上是固定的或可简单预测的,您可以将其作为输入传递给预先分配的。这是可行的,因为数组首先通过引用有效地传递给函数。
关于java - Swig:将返回类型 std::string(binary) 转换为 java byte[],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12192624/
我对以下树的术语感到困惑,我一直在研究树,但无法区分这些树: a) 完全二叉树 b) 严格二叉树 c) 完整二叉树 请帮我区分这些树。这些树何时何地在数据结构中使用? 最佳答案 完美的树:
我正在检查数字系统并在它们之间进行转换。 我认为十六进制值比二进制使用更少的位,这是有道理的,但最终十六进制值不是存储为位吗?这似乎最终打败了目的。 最佳答案 几乎在所有情况下,计算机使用的所有数据最
任何人都可以在 Cudd 包上指出一些好的 Material 吗?我在这里寻找一些简洁的事情。位于 http://vlsi.colorado.edu/~fabio/CUDD/ 的那个似乎没有对此事做出
我正在检查数字系统并在它们之间进行转换。 我认为十六进制值比二进制使用更少的位,这是有道理的,但最终十六进制值不是存储为位吗?这似乎最终打败了目的。 最佳答案 几乎在所有情况下,计算机使用的所有数据最
在我的应用程序中,我需要序列化一个包含任意数据类型的向量,在本例中是一个 Doubles 列表。为了序列化我正在导入 Data.Vector.Binary 的向量。 在 GHCi 中加载模块时出现以下
我尝试通过 sqlalchemy 将二进制文件存储到 postgresql 中,并从客户端上传文件。 对错误消息的一点谷歌把我带到 this source file :“包装的对象不是字节或缓冲区,这
我从表(源)中执行 INSERT SELECT,其中每列都是 VARCHAR 数据类型。 其中一列存储二进制数据,例如 '0003f80075177fe6' 我插入的目标表具有相同的列,但具有正确的数
无法简单地将二进制文件复制到 Linux 机器。哇!我今天觉得很蠢!以下是从默认镜像和 utah.edu 下载的二进制包的 tar.gz 中的文件列表: -rwxr-xr-x 1 ec2-user e
我正在阅读关于 Binary search 的不同 Material ,我不清楚它是一个贪婪的二进制文件(在我看来它不是)或者,它可以是一个具有某些特定实现的贪婪算法吗? 如果它可以是贪心的,它有什么
我见过这样写的代码: ifstream fin; fin.open("largefile.dat", ifstream::binary | ifstream::in); 现在这让我感到困惑,上面的代码
binary(10) vs char(10)character set binary有什么区别? 还有varbinary(10) vs varchar(10)字符集二进制? 它们在所有 MySQL 引
binary(10) vs char(10)character set binary有什么区别? 还有varbinary(10) vs varchar(10)字符集二进制? 它们在所有 MySQL 引
我尝试将一些数据插入到从 mysql 中的另一个表检索的表中,该表的数据类型为 BINARY(20)。 提取的数据位于变量$binary['hash']; /l÷ˆ8Ô]¿\µK prepare("I
在我的一个站点上,我有一个主用户表,其中包含每个用户的唯一用户 ID、电子邮件地址、密码等。 我需要开始跟踪很多与每个用户相关的二进制标志,比如他们是否确认了他们的电子邮件,他们是否发布了消息,他们是
在最近 SO discussion我展示了一个需要修剪顶点 6 和 7 的二叉分类树: 下面是我使用的代码: KaryTree[9, 2, VertexLabels -> {1 -> "Blood
请解释一下,对于以下查询,在 Mysql 中哪个会更快? SELECT * FROM `userstatus` where BINARY Name = 'Raja' [OR] SELECT * FRO
我通过定义 ngram_vectorizer = CountVectorizer(binary=True) 和 ngram_vectorizer = CountVectorizer(binary=Fa
在 C++ 中搜索文件读取示例时,我注意到许多示例使用 std::ios::binary 与 std::ifstream::binary std::ios::beg 与 your_file_strea
我在这里和其他论坛上看到过旧帖子,其代码与下面的代码类似,但无法弄清楚其中的一部分来自哪里。 let Source = Table.FromRows(Json.Document(Binary.
#include #include #define SIGBAD(signo) ((signo) = NSIG) int sigaddset(sigset_t *set, int signo
我是一名优秀的程序员,十分优秀!