我正在尝试使用 SWIG 包装(在 C# 中)一些包含模板类的 c++ 代码,该模板类本身包装了 std::vector<T>
.我在互联网上看到了有关如何为 vector 类型声明模板的各种引用资料,但无法使其与额外的抽象层一起使用。这就是我在 interface.i 文件中所做的,例如:
// interface.i file
%module myNamespaceWrapper
%{
#include "myVector.h"
%}
%include "myVector.h"
%include "std_string.i"
%include "std_vector.i"
namespace std {
%template(vector_MyType) vector<MyType*>;
%template(vector_Int) vector<int>;
}
namespace myNamespace {
%template(myVectorMyType) myVector<MyType*>;
%template(myVectorInt) myVector<int>;
}
虽然这似乎可以自行正确创建相应的 C# 类型,但我尝试定义的 std::vector 模板不适用于在内部使用它们的其他类,包括头文件。为了向您展示我的意思,有一个 c++ 类,例如:
// myVector.h
namespace myNamespace
{
template<class T>
class myVector
{
private :
std::vector<T> vect;
public :
myVector(){}
virtual ~myVector(){}
virtual const std::vector<T> & getVect()
{
return vect;
}
virtual T& front()
{
return vect.front();
}
}
}
即使我得到 vector_MyType
由 SWIG 创建的类,当它包装我的模板类时,它没有使用它,而是提供了很多这样的示例:
public class myVectorMyType : global::System.IDisposable {
public virtual SWIGTYPE_p_p_myNamespace__MyType front() {
SWIGTYPE_p_p_myNamespace__MyType ret = new SWIGTYPE_p_p_myNamespace__MyType(myNamespaceWrapperPINVOKE.myVectorMyType_front__SWIG_0(swigCPtr), false);
return ret;
}
public virtual SWIGTYPE_p_myNamespace__std__vectorT_myNamespace__MyType_p_t getVect() {
SWIGTYPE_p_myNamespace__std__vectorT_myNamespace__MyType_p_t ret = new SWIGTYPE_p_myNamespace__std__vectorT_myNamespace__MyType_p_t(myNamespaceWrapperPINVOKE.myVectorMyType_getVect(swigCPtr), false);
return ret;
}
}
请有人建议我缺少什么让 SWIG 使用 MyType
生成包装器和 vector_MyType
而不是 SWIGTYPE_p_myNamespace__std__vectorT_myNamespace__MyType_p_t
和 SWIGTYPE_p_p_myNamespace__MyType
?
这是否与返回 T&
的模板 getVect() 函数有关? ,即我需要为 %template(myVectorInt) myVector<int>;
做任何不同的事情吗?案例,其中 int
不是指针吗?
最佳答案
我建议避免这个问题,只为您需要的每个实例创建包装器:
class wrap_int : public temp <int>
{
};
关于c# - 包装包含 vector 的模板类时如何让 SWIG 应用模板?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29699543/