首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >跨流程边界的CRT类型

跨流程边界的CRT类型
EN

Stack Overflow用户
提问于 2010-07-06 15:22:39
回答 1查看 236关注 0票数 1

我正在从一个activeX控件中拖放。在拖动时,我提供了一个CComQIPtr,它的COM方法实现了将信息传递给drop目标。在删除时,drop目标的进程调用我的COM方法来获取信息。

是否允许在界面边界附近使用CRT类型或指向CRT类型的指针?我希望我的IDataObject有一个私有的std::list和一些std::字符串,并且在接口的外部可以调用我的COM方法来访问那些私有成员。

我认为这是可以的,因为我实际上并没有跨越边界传递CRT类型。

MSDN:跨DLL边界传递CRT对象的潜在错误

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2010-07-06 15:35:43

您可以在com对象的实现中使用您喜欢的任何东西,因为它总是停留在创建com对象的进程(或dll)中。

您需要坚持COM接口中的COM类型,以便可以在使用对象的进程和创建对象的进程之间封送类型。

你是对的。这篇文章不适用于这种情况,因为您没有跨越边界传递任何内容。COM基础结构负责为您跨边界编组COM类型。

只要确保捕获COM方法中的所有异常,就不能让它们泄漏出函数,因为COM基础结构不知道如何处理它们。

就我个人而言,我倾向于有一层很薄的COM代码来处理COM类型和“正常”类型之间的转换,然后调用执行实际工作的代码(请参阅这里)。该层包含一个异常处理程序,它捕获所有内容并转换为适当的HRESULT。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3187640

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档