我想在C++中实现一个类,其目的是为C样式对象实现RAII机制。
然后,我需要能够将此类的实例传递给所有接收所述C样式对象作为参数的C样式函数。我知道应该使用unique_ptr
解决此问题,但是我暂时不能使用C++11
。无论如何,无论是否有更好的解决方案,我都希望了解如何进行。
对于必须重载哪些运算符以及它们之间的区别,我有一些疑问。
下面是我实现的代码示例。我特别对运营商1和2感到困惑(有什么区别?)
我想知道我实现的代码是否涵盖了所有用例,即C库可以使用该对象的所有场景。另外,我想了解运算符1和2之间的区别。
C样式 object
// Example: a C-style library called "clib" which use an object called "cobj":
struct cobj {
int n;
};
void clib_create_cobj(struct cobj **obj) {
*obj = (struct cobj*)malloc(sizeof(cobj));
(*obj)->n = 25;
}
void clib_release_cobj(struct cobj *obj) {
free(obj);
}
void clib_doSomething(struct cobj *obj) {
std::cout << obj->n << std::endl;
}
C++“透明”包装器
// My wrapper class for implementing RAII
class CobjWrapper {
public:
CobjWrapper(struct cobj *obj) : m_obj (obj) { }
~CobjWrapper() {
if(m_obj != NULL) {
clib_release_cobj(m_obj);
m_obj = NULL;
}
}
operator struct cobj* () const { // (1)
return m_obj;
}
struct cobj& operator * () { // (2)
return *m_obj;
}
struct cobj** operator & () { // (3)
return &m_obj;
}
struct cobj* operator->() { // (4)
return m_obj;
}
private:
struct cobj *m_obj;
};
主要方法
// The main method:
int main() {
struct cobj *obj = NULL;
clib_create_cobj(&obj);
CobjWrapper w(obj);
clib_doSomething(w);
return 0;
}
可以在此处测试以上来源:
http://cpp.sh/8nue3
最佳答案
以下是隐式强制转换
operator struct cobj* () const { // (1)
带有示例用法
CobjWrapper wrapper = /**/;
struct cobj* obj = wrapper;
而以下是一元
operator *
struct cobj& operator * () { // (2)
带有示例用法
CobjWrapper wrapper = /**/;
struct cobj& obj = *wrapper;
顺便说一句,我会完全隐藏C结构,例如:
class CobjWrapper {
struct ObjDeleter
{
void operator()(cobj *obj) const { clib_release_cobj(obj); }
};
public:
CobjWrapper()
{
cobj *obj = nullptr;
clib_create_cobj(&obj);
m_obj.reset(obj);
}
void doSomething() { clib_doSomething(m_obj.get()); }
private:
std::unique_ptr<cobj, ObjDeleter> m_obj;
};