C++/CLR 类中的 CComPtr 成员
Member CComPtr in a C++/CLR class
我正在编写一个 C++/CLI 类,该类需要在其生命周期内保持CComPtr
,例如
public ref class MyClass
{
public:
MyClass()
{
CComPtr<ISomeType> pSomeType;
// init someType;
m_pSomeType = pSomeType;
}
private:
CComPtr<ISomeType> m_pSomeType;
void DoSomething()
{
m_pSomeType->DoSomething();
}
}
但是这不能编译,因为不支持混合类型 - 解决方案是使用 AutoPtr
. 我仍然需要参考计数,所以这就是我想出的。
public ref class MyClass
{
public:
MyClass()
{
CComPtr<ISomeType> pSomeType;
// init someType;
m_pSomeType = new CComPtr<ISomeType>(pSomeType);
}
private:
AutoPtr<CComPtr<ISomeType>> m_pSomeType;
void DoSomething()
{
CComPtr<ISomeType> pSomeType = *m_pSomeType.GetPointer();
pSomeType->DoSomething();
}
}
这对我来说看起来很讨厌,我也怀疑它在某种程度上是错误的(我来自 C# 背景,所以我在学习的过程中学到了很多东西)。
如何将CComPtr
"存储"为 C++/CLR 类的成员?
我做了一个智能指针,可能会对你有所帮助。 它不能用于直接管理 COM 指针,但可用于在托管类中保存 CComPtr。
- C++/CLI 的scoped_ptr(确保托管对象正确释放拥有的本机对象)
如果您选择使用它,请遵守许可要求(不禁止商业用途,但您必须注明出处)。
另外,你可以写
(*m_pSomeType)->DoSomething();
而不是复制CComPtr
(必须更新引用计数)。
除此之外,我会在构造函数中使用 ctor-initializer-list 而不是赋值。
MyClass()
: m_pSomeType(new CComPtr<ISomeType>)
{
}
如果要分别编译托管和非托管代码,则此处有一个链接。
使用它,您可以保留两者的味道。
相关文章:
- 将成员变量添加到共享库中的类中,不会破坏二进制兼容性吗
- 对RValue对象调用的LValue ref限定成员函数
- 为什么使用 "this" 指针调用派生成员函数?
- 具有奇怪重复模板模式的派生类中的成员变量已损坏
- 助记符和指向成员语法的指针
- 用于访问容器<T>数据成员的正确 API
- 内置函数可查看CPP中的成员变量
- 是否可以初始化不可复制类型的成员变量(或基类)
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 找不到成员对象:没有名为get_event()的成员,也处理多态性和向量
- 嵌套在类中时无法设置成员数据
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 将函数类成员映射到类本身内部
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 将Ref对象作为类成员
- 将包含C样式数组的对象初始化为成员变量(C++)
- 静态数据成员的问题-修复链接错误会导致编译器错误
- 将公共但非静态的成员函数与ALGLIB集成
- 多成员Constexpr结构初始化
- C++/CLR 类中的 CComPtr 成员