混合托管和非托管C++代码
Mixing managed and unmanaged C++ code?
我有几个关于混合托管C++与非托管C++的具体问题:
- 如果我在类/结构声明中省略
ref
和value
,这是否会自动使类/结构不受管理?还是我仍然需要包含#pragma unmanaged
和#pragma managed
指令? - 非托管类型和托管类型的兼容性如何?例如,我可以在托管类中有一个非托管对象,对吗?我可以将非托管类/结构传递给托管函数(即将 std::string 传递给托管函数)吗?
感谢您的帮助,
亚历克斯
不能有混合类型(包含托管对象的本机类,反之亦然)。 可能的方法是在托管类中有一个指向本机类的指针,并在本机类中有一个用gcroot
模板包装的托管句柄。 这是确保垃圾回收器永远不会尝试移动本机数据所必需的(这会破坏纯本机代码持有的指针)。
类型始终使用托管代码实现。 如果本机类型调用托管类型,则必须使用托管代码实现这些类型。
#pragma managed(push, off)
是强制将代码编译为本机代码的方法。 这样做有几个原因:C++编译器的更好优化,不能被垃圾回收等打断。 或者,您可以使用/clr:pure
强制将所有代码编译为托管代码,甚至可以/clr:safe
执行相同的操作并使其可验证。
编译为托管的任何代码都可以接受本机类型和托管类型作为参数和返回值。 该代码可以位于托管类型、本机类型或自由(全局)函数中。
相关文章:
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 代码在main()中运行,但在函数中出现错误
- 在VS代码中交叉编译Windows与Linux上的MinGW的SDL程序
- 编译包含字符串的代码时遇到问题
- 我在c++代码中生成了一个运行时#3异常
- 如何在linux终端中同时编译和运行c++代码
- 为cl.exe(Visual Studio代码)指定命令行C++版本
- 在Linux for Windows上编译C++代码时出错
- 我的字符计数代码计算错误.为什么
- 孤立代码块在结构中引发异常
- 在编译C++代码(具有dlib和opencv)到WASM时面临问题
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 此代码是否违反一个定义规则
- 为什么我的代码在输出中增加了93天
- 我的简单if-else语句是如何无法访问的代码
- 使用动态分配的数组会导致代码分析发出虚假的C6386缓冲区溢出警告
- 为什么在这个代码结束循环中没有得到结束
- 在c代码之间共享数据的最佳方式
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值