2

我正在编写一个 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我应该如何将 a作为 C++/CLR 类的成员“存储” ?

4

2 回答 2

2

我制作了一个智能指针,可能会对您有所帮助。它不能用于直接管理 COM 指针,但可以用于在托管类中保存 CComPtr。

如果您选择使用它,请尊重许可要求(不禁止商业使用,但您必须给予信任)。

另外,你可以写

(*m_pSomeType)->DoSomething();

而不是复制CComPtr(必须更新引用计数)。

除此之外,我会在构造函数中使用ctor-initializer-list而不是赋值。

MyClass()
    : m_pSomeType(new CComPtr<ISomeType>)
{
}
于 2012-08-06T16:40:54.763 回答
0

如果您想分别编译托管和非托管代码,那么这里有一个链接。

使用它,您可以保留两者的风味。

于 2012-08-06T16:15:23.857 回答