在 windows程序中,不同exe间不能随意访问彼此的内存,那么若想实现此功能,怎么办?dll登场。
何为dll?
DLL是Dynamic Link Library的缩写,意为动态链接库。在Windows中,许多应用程序并不是一个完整的可执行文件,它们被分割成一些相对独立的动态链接库,即DLL文件,放置于系统中。当我们执行某一个程序时,相应的DLL文件就会被调用。一个应用程序可有多个DLL文件,一个DLL文件也可能被几个应用程序所共用,这样的DLL文件被称为共享DLL文件。(百度百科)其实就是封闭好的函数库。
如何生成dll文件
- 在VS2013中,新建项目选择Win32控制台应用程序,输入项目名字。
- 选择dll,空项目。
- 在正常声明的函数前,增加_declspec(dllexport) 即可 。
以下是一个通过动态库修改其他程序内存地址值的例子。
A程序如下:
运行结果如下:
编写的动态库:
生成dll。
使用dll注入工具,将生成的dll注入到原来的程序a中,修改内存值,发现原来a程序的值发生了变化。