有些时候,为了使用别人已经写好的C#库文件,我们需要使用C++调用C#库文件; 以下做了一简单的调用工程,步骤如下:
1、准备C#库 (dll文件)
1)创建C#库:
![](https://images0.cnblogs.com/blog2015/31805/201508/021054021571543.png)
2)编写C#类:
![](https://images0.cnblogs.com/blog2015/31805/201508/021054152517276.png)
3)配置C#库工程相关配置
(1)命名空间配置,输出库文件名配置:
![](https://images0.cnblogs.com/blog2015/31805/201508/021054342829761.png)
(2)库文件输出路径:
![](https://images0.cnblogs.com/blog2015/31805/201508/021114402829121.png)
2、准备C++工程:
1)创建C++工程:
![](https://images0.cnblogs.com/blog2015/31805/201508/021055076733495.png)
![](https://images0.cnblogs.com/blog2015/31805/201508/021055182981416.png)
2)CLR支持(公共语言运行支持):
![](https://images0.cnblogs.com/blog2015/31805/201508/021055290649591.png)
3)引用和调用C#代码:
![](https://images0.cnblogs.com/blog2015/31805/201508/021056489397089.png)
4)编译直接运行:
![](https://images0.cnblogs.com/blog2015/31805/201508/021057036261537.png)
5)运行调试:
![](https://images0.cnblogs.com/blog2015/31805/201508/021057113768702.png)
3、其他补充说明:
1)为什么使用gcnew 而不使用 new ?
C++/CLI中使用 gcnew 关键字用来表示 在托管堆上分配内存,并且区分其他指针的区别,使用 ^ 来代替 * 作为指针含义, 语义上大致如下:
(1)、gcnew返回的是一个句柄(handle), 而new 返回的是实际的内存地址
(2)、gcnew创建的对象由虚拟机托管,而new创建的对象必须自己来管理和释放
在此不是有C++本身来分配内存空间,而是由其他虚拟机托管分配,并且不需要C++程序来释放空间
如果想了解CLI更详细情况,可以参考:
2)使用#using 宏引入dll库文件, 而不是 #pragma comment(lib, "")
后面主要用于引入C/C++库文件
3)执行时可能会出现以下问题:
![](https://images0.cnblogs.com/blog2015/31805/201508/021057414391051.png)
主要是由于exe程序加载的dll文件不存在或未找到,可以:
将C#的库文件和pdb文件 输出到一个公共的文件夹下:如: ..\Out\Debug\ 文件夹
将C++的编译程序exe和pdb文件也输出到该公共文件夹下,
![](https://images0.cnblogs.com/blog2015/31805/201508/021058106731987.png)
Linker配置:
![](https://images0.cnblogs.com/blog2015/31805/201508/021058210175992.png)
4、例程源码:
http://download.csdn.net/detail/vagent/8953189