动态加载比静态加载难一些
这里是针对windows下的API来讨论动态加载
首先windows下的动态加载是靠三个函数来实现的
#include <windows.h>
LoadLibrary();
GetProcAddress();
FreeLibrary();
这三个函数我们可以理解为对文件的
open();
read/write();
close();
操作
首先
我们先看动态链接库提供的.h头文件
这里有三个不一样的声明的函数,由于__declspec(dllexport)我们在动态链接库之静态加载讲过了,所以这里我们只讨论前两个函数的问题
我们再看.cpp文件里面的内容
我们这里对动态链接库里面的两个函数进行操作,以示区别
编译执行后发现错误,这里的意思是,我们并没有在.dll文件里面找到Sub的函数,但是Add函数执行却是成功的
我们再去.dll文件里面去查看原因
发现我们能Sub的函数名在底层被改成了?Sub@@YAHHH@Z
而加了关键字extern"C"编译后的.dll文件里的Add函数,却被链接成了Add
我们尝试去用?Sub@@YAHHH@Z去寻找.dll却意外的发现调用成功了
这个问题其实是C和C++的兼容问题
extern "C"关键词是让我们说明这个函数用C语言的方式去编译链接
而没有加就会用C++的方式去链接
而我们都知道,C++支持重载而C语言并不支持重载
所以在底层C++对函数的命名方式会比C语言复杂
而我们C++调用.dll库,其实我们C++并不知道这个库里面是用C++编译器编译过的还是C语言编译过的
C++编译过的库在底层链接的命名会跟C语言有很大的区别
一个C++的工程调用一个库函数只会根据.dll文件的命名去查找匹配,并不会分析它是用什么编译器编译过的,所以我们C++调用的中库必须加上extern "C"关键字