动态链接库之动态加载

动态加载比静态加载难一些

这里是针对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"关键字

发布了23 篇原创文章 · 获赞 15 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/TanJiaLiang_/article/details/86573629