- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
使用 vector
结构一切正常
%include <std_vector.i>
%typemap(javaout) const S1& std::vector<S1>::get {
//custom code
}
struct S1 {};
std::vector<S1> val;
%template(vector_s1) std::vector<S1>;
但不适用于指针的vector
%include <std_vector.i>
%typemap(javaout) const S1*& std::vector<S1*>::get {
//custom code
}
struct S1 {};
std::vector<S1*> val;
%template(vector_s1) std::vector<S1*>;
示例是使用 swig -java -c++ -module sample sample.i
SWIG 版本:
$ swig -version
SWIG Version 3.0.7
Compiled with i586-mingw32msvc-g++ [i586-pc-mingw32msvc]
Configured options: +pcre
最佳答案
如果您查看文件 swig/Lib/std/std_vector.i
为 std::vector
提供与语言无关的包装代码,您会发现以下评论:
// ***
// This specialization should disappear or get simplified when
// a 'const SWIGTYPE*&' can be defined
// ***
template<class _Tp, class _Alloc >
class vector<_Tp*, _Alloc > { ...
看来 SWIG 目前无法处理 const S1*&
在您上面的类型映射定义中。
现在,文件 swig/Lib/java/std_vector.i为 std::vector
提供 java 包装器不那么复杂并且缺乏 std::vector<T*>
的特化.
自己添加这样的专业应该可以解决您的问题:
文件 std_vector_pointer.i
:
%include <std_vector.i>
namespace std {
template<class T> class vector<T*> {
public:
typedef size_t size_type;
typedef T* value_type;
typedef value_type const_reference;
vector();
vector(size_type n);
size_type size() const;
size_type capacity() const;
void reserve(size_type n);
%rename(isEmpty) empty;
bool empty() const;
void clear();
%rename(add) push_back;
void push_back(T* x);
%extend {
T* get(int i) throw (std::out_of_range) {
int size = int(self->size());
if (i>=0 && i<size)
return (*self)[i];
else
throw std::out_of_range("vector index out of range");
}
void set(int i, T* val) throw (std::out_of_range) {
int size = int(self->size());
if (i>=0 && i<size)
(*self)[i] = val;
else
throw std::out_of_range("vector index out of range");
}
}
};
}
那么以下内容应该适用于您上面的示例:
%include "std_vector_pointer.i"
%typemap(javaout) S1* std::vector<S1*>::get {
//custom code
}
struct S1 {};
std::vector<S1*> val;
%template(vector_s1) std::vector<S1*>;
关于javaout typemap 不适用于 std::vector of pointers,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33938455/
当我使用 int 时一切正常 - %immutable S::field; %typemap(javaout) int S::field { //custom code } struct S {
使用 vector 结构一切正常 %include %typemap(javaout) const S1& std::vector::get { //custom code } struct S
问题 我正在开发一个 Android 应用程序,其中我必须在 Java 代码和 C++ 代码之间传递 OpenCV Mat。为此,我创建了以下工作正常的 SWIG 类型映射: %include "st
我是一名优秀的程序员,十分优秀!