使用VS2015编译和调用动态链接库dll

时间:2022-09-17 14:37:45
【文件属性】:
文件名称:使用VS2015编译和调用动态链接库dll
文件大小:47KB
文件格式:RAR
更新时间:2022-09-17 14:37:45
dll c++ cpp 使用VS2015编译和调用动态链接库dll 1. 首先建工程,选择dll,记得勾上“导出符号” 后面不用自己搞那些宏定义会省事很多。 建立工程myDll,记得勾上“导出符号” 类型选择dll 2. IDE自动生成的代码已经把整个架构弄好了,其中和项目同名的.h和.cpp文件就是我们自己写代码的地方了。我想写的dll是导出一个类,在这里我就直接在它自动生成的CmyDll类上面改了。 myDll.h myDll.cpp 在mydll.h和mydll.cpp中给类添加成员函数 //mydll.h class MYDLL_API CmyDll { public: CmyDll(void); // TODO: 在此添加您的方法。 int myFunction(int a, int b); }; //mydll.cpp int CmyDll::myFunction(int a, int b) { return a*b; } 3.编译的时候我选择了release,这里可以用默认的debug也行 在mydll.h和mydll.cpp中给类添加成员函数 最后生成解决方案后产生的mydll.lib和mydll.dll就是我们需要的二进制文件了。lib文件是编译是要用的,而dll是调用这个库的程序运行时需要的。 调用dll 1.重新建立一个工程 这回选择普通的控制台程序就行了。我建了个名为myDllCall的工程。 2.把库的头文件include进来,以及连接lib文件 其中 include进来的 myDll.h 和 **#pragma comment()**的lib根据自己的路径写。 #include "stdafx.h" #include "../../myDll/myDll/myDll.h" //头文件 #pragma comment(lib,"../../myDll/Release/myDll.lib") //调用自己写的外部库 #include int main() { CmyDll mydll; int a, b; std::cin >> a >> b; std::cout << mydll.myFunction(a, b) << std::endl; std::cin >> a >> b; std::cout << mydll.myFunction(a, b) << std::endl; return 0; } 3.dll放到可执行文件同一目录下面 刚刚的代码直接编译没问题,运行会报错. 直接编译没问题,运行会报错 原因是dll要和生成的可执行文件在同一个目录下,我把mydll.dll放进去之后就解决了。 我们成功的在自己的工程里调用了外部的类 可以看到我们成功的在自己的工程里调用了外部的类。
【文件预览】:
myDll
----.vs()
--------myDll()
----myDll.sln(1KB)
----Release()
--------myDll.lib(3KB)
--------myDll.dll(9KB)
----myDll()
--------myDll.vcxproj(9KB)
--------stdafx.cpp(209B)
--------stdafx.h(315B)
--------dllmain.cpp(389B)
--------targetver.h(240B)
--------myDll.cpp(395B)
--------myDll.h(651B)
--------myDll.vcxproj.filters(1KB)
--------ReadMe.txt(1KB)
----myDll.sdf(320KB)
myDllCall
----.vs()
--------myDllCall()
----myDllCall()
--------stdafx.cpp(213B)
--------myDllCall.vcxproj(8KB)
--------stdafx.h(234B)
--------targetver.h(240B)
--------myDllCall.vcxproj.filters(1KB)
--------myDllCall.cpp(401B)
--------ReadMe.txt(1KB)
----myDllCall.sln(1KB)
----myDll.dll(9KB)
----Debug()
--------myDllCall.exe(36KB)
--------myDll.lib(3KB)

网友评论

  • 还不错,解释清楚很好可以用的。