第5章 动态链接

 
第5章 动态链接

1、从DLL中输出函数:用extern "c"标记。

2、在使用VC时,可以用DUMPBIN。EXE来得到某个DLL中所输出的符号的清单。如下面的命令:

dumpbin -exports Cmpnt1.dll

3、装载DLL:LoadLibrary以被装载的DLL的名称作为参数并返回一个指向所装载的DLL的句柄。

win32的GetProcAddress函数可以使用此句柄以及待用的函数的名称,然后返回一个指向次函数的指针。

4、使用DLL实现组件的原因:DLL可以共享它们所链入的应用程序的地址空间。

当进程被加载时,系统为它分配一个4GB的地址空间,接着分析该可执行模块,找到该进程将要调用哪些DLL,然后系统搜索这些DLL,找到后就加载它们,并为他们分配虚拟的内存空间,最后将DLL的页面映射到调用进程的地址空间。如果这个时候第二个进程也启动了,并且它也需要访问该DLL,这时,只需要将该DLL在虚拟内存中的代码页面和数据页面映射到第二个进程的地址空间即可。在内存中,只需要存在一份DLL的代码和数据。多个进程可以共享DLL的同一份代码,这样就可以节省内存空间。

5、完整的组件和客户程序的实现源码:CSDN我的资源中InsideCOM\CHAP05XXX。

 

你可能感兴趣的:(c,dll,exe)