我可以为任何c++向量做一个C包装器吗?
Can I make one C wrapper for any C++ vector that could go in a Extern C
我需要一个C包装器,用于任何可以传递给期望某种特定类型向量的函数的c++向量。就像我下面的C包装器OpenCV的轻快"
void cv_BRISK_generateKernel(BRISK* self, vector_float* radiusList,
vector_int* numberList, float dMax, float dMin, vector_int* indexChange) {
self->generateKernel(*radiusList, *numberList, dMax, dMin, *indexChange);
}
vector_int*
和vector_float*
为typedef
,如下
typedef vector<int> vector_int;
typedef vector<float> vector_float;
这些是我到目前为止的向量包装器,它们工作,但我想知道是否有一种方法可以为所有向量类型制作一个包装器。它必须放在Extern C中,所以它不能是模板。但是,而不是有下面的包装器,我想只做一个包装器,可以传递给一个函数期望vector_float*
(typedef
vector<float>
)或vector_KeyPoint*
(typedef
vector<KeyPoint>
)或vector_int*
(typedef
vector<int>
)等。我知道模板类,但我不能在这里使用它们因为它必须放在extern C {}
vector_float* std_create_vectorf() {
return new vector<float>;
}
vector_int* std_create_vector() {
return new vector<int>;
}
vector_char* std_create_vectorc() {
return new vector<char>;
}
这是我理想的包装,如果有人能帮我弄清楚如何做到这一点,我将不胜感激
vector_any_vec* std_create_vectorany() {
return new vector<anyvector>;
}
如何使用运行时多态性将其封装在接口中?你牺牲了一点类型安全,但它应该达到你所需要的。
enum stored_type
{
st_int,
st_float,
st_char
};
struct IGeneralVector
{
virtual stored_type get_type() = 0;
virtual void* get_data() = 0;
virtual ~IGeneralVector();
};
class VectorFloatHolder : public IGeneralVector
{
std::vector<float>* data;
public:
VectorFloatHolder(std::vector<float>* in) : data(in)
{}
virtual stored_type get_type() override
{
return st_float;
}
virtual void* get_data() override
{
return reinterpret_cast<void *>(data);
}
virtual ~VectorFloatHolder()
{
delete data;
}
};
IGeneralVector* std_create_vectorf()
{
return new VectorFloatHolder(new std::vector<float>);
}
看了你的评论后,我对你想要达到的目标有了稍微更好的了解。但我不确定是否有可能做到你想要的,因为我不确定你有任何其他的实现约束。这里有另一种方法,这次使用类型擦除。
class ObjectHolder
{
struct base_type
{
virtual ~base_type() {}
};
template<typename T>
struct object_type : base_type
{
object_type(const T& t) : object(t) {}
T object;
};
std::unique_ptr<base_type> data;
public:
template<typename T>
VectorHolder(T t) : data(new object_type<T>(t))
{
}
template<typename T>
T GetData()
{
object_type<T>* val = static_cast<object_type<T>*>(data.get());
return val->object;
}
};
template<typename T>
ObjectHolder* std_create_vector()
{
return new VectorHolder(new std::vector<T>);
}
int main()
{
ObjectHolder* vh = std_create_vector < std::vector<float>>();
// then later on you can get back the original type via:
std::vector<float>* fp = vh->GetData<std::vector<float>*>();
}
相关文章:
- 如何在c++17中制作一个模板包装器/装饰器
- 将 N-arg 函数包装到另一个函数中
- 包装一个对象并假装它是一个 int
- 如何包装一个函数以适应另一个函数的所需类型
- 包装器是从 strcat_s() 到 strcat() 吗?如果没有,是否可以创建一个?
- 如何将 c++ 类包装到 python 中,以便我可以使用 pybind11 访问其成员的公共方法(成员是一个对象指针)
- 用输出参数包装一个c++函数,以便在javascript/node中使用
- PYBIND11:如何将C 和Python代码包装到一个包装中
- c++11:如何编写一个包装函数来生成"std::function"对象
- OpenCv c++为基本的打印垫函数创建一个c包装器
- Objective-C - 为C++函数创建一个包装器文件
- 用我自己的例外编写一个包装器
- 围绕可以通过C链接器链接的C++库创建一个C包装器
- 如何在Cython中从另一个包装对象返回包装的c++对象
- 如何编写一个包装器,使其保持对输出的跟踪
- 为ActiveMQ制作一个包装器类
- 我如何在c#上为一个包装的c++方法写一个签名,该方法的参数中有一个指向函数的指针
- 为std算法函数创建一个包装器,用容器代替迭代器
- 我可以为任何c++向量做一个C包装器吗?
- 如何为delete编写一个C包装器,既快速又释放给定的任何类型,而不告诉它是什么类型