VC++ 使用attributes定义接口

 

1.定义预处理命令_ATL_ATTRIBUTES

image

2.在一个全局的Cpp文件里面配置module的attribute

[module(dll, uuid = "{3845951F-15B8-4286-8E7D-E9D4F5C7B6CE}", 
    name = "TestApp")]

3.定义接口

[
    object,
    uuid("9F414A8A-1D5E-4aff-A60E-CFD65155ABB6"),
    dual, helpstring("IGFCursorMgr Interface"),
    pointer_default(unique)
]
__interface IEmployee : IDispatch
{
    HRESULT DoWork(BSTR bstrTask);
};

[
    coclass,
    default(IEmployee),
    threading(free),
    vi_progid("TXGF.CGFCoCursorMgr"),
    progid("TXGF.CGFCoCursorMgr.1"),
    version(1.0),
    uuid("20BB9542-E499-4618-9E2D-079A06FD99B1"),
    helpstring("CGFCoCursorMgr Class")
]
class ATL_NO_VTABLE CManager:public IEmployee
{
public:

    CManager()
    {
        //InternalAddRef();
    }

    DECLARE_PROTECT_FINAL_CONSTRUCT()

    HRESULT FinalConstruct()
    {
        return S_OK;
    }

    void FinalRelease()
    {}

    HRESULT DoWork(BSTR bstrTask)
    {
        CComObject<CManager> * pObj = NULL;
        CComObject<CManager>::CreateInstance(&pObj);
        return S_OK;
    }
};

4.引用ATL命名空间

如遇编译错误error C3358: 'IDispatchImpl': symbol not found

需要添加ATL的命名空间using namespace ATL;

 

关于使用的参考资料:http://msdn.microsoft.com/en-us/magazine/cc301337.aspx

      The generated code in Figure 6 shows that the [coclass] attribute makes the compiler derive a class from CComObjectRootEx<> and this provides QueryInterface through the interface map. The compiler generates this map by looking at the interfaces that the class is derived from. If you want to add your own entries to this map, you can use the [com_interface_entry()] attribute. The parameter to this attribute is the COM_INTERFACE_ENTRY macro that you want to add to the top of the map. For example:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值