dll动态链接库文件不是已经被编译和链接好的二进制文件了吗?怎么还会被损坏呢?
答案:2 悬赏:0 手机版
解决时间 2021-02-19 04:09
- 提问者网友:浮克旳回音
- 2021-02-18 06:47
不是封装好了吗,难道DLL还可以被修改????
最佳答案
- 五星知识达人网友:逃夭
- 2021-02-18 07:56
当然可以修改了。Dll和EXE文件格式类似,你的EXE文件可以被修改,DLL文件当然也可以被修改了。Dll中除去重定位等信息,还包含机器码也就是CPU可执行的指令,这些都是可以修改的。
全部回答
- 1楼网友:从此江山别
- 2021-02-18 09:06
一、动态链接库的概念
动态链接库(dynamic link library,缩写为dll)是一个可以被其它应用程序共享的程序模块,其中封装了一些可以被共享的例程和资源。动态链接库文件的扩展名一般是dll,也有可能是drv、sys和fon,它和可执行文件(exe)非常类似,区别在于dll中虽然包含了可执行代码却不能单独执行,而应由windows应用程序直接或间接调用。
动态链接是相对于静态链接而言的。所谓静态链接是指把要调用的函数或者过程链接到可执行文件中,成为可执行文件的一部分。换句话说,函数和过程的代码就在程序的exe文件中,该文件包含了运行时所需的全部代码。当多个程序都调用相同函数时,内存中就会存在这个函数的多个拷贝,这样就浪费了宝贵的内存资源。而动态链接所调用的函数代码并没有被拷贝到应用程序的可执行文件中去,而是仅仅在其中加入了所调用函数的描述信息(往往是一些重定位信息)。仅当应用程序被装入内存开始运行时,在windows的管理下,才在应用程序与相应的dll之间建立链接关系。当要执行所调用dll中的函数时,根据链接产生的重定位信息,windows才转去执行dll中相应的函数代码。
一般情况下,如果一个应用程序使用了动态链接库,win32系统保证内存中只有dll的一份复制品,这是通过内存映射文件实现的。dll首先被调入win32系统的全局堆栈,然后映射到调用这个dll的进程地址空间。在win32系统中,每个进程拥有自己的32位线性地址空间,如果一个dll被多个进程调用,每个进程都会收到该dll的一份映像。
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯