动态库DLL 的一些疑问
一般情况下,如果一个应用程序使用了动态链接库,Win32系统保证内存中只有DLL的一份复制品,这是通过内存映射文件实现的。DLL首先被调入 Win32系统的全局堆栈,然后映射到调用这个DLL的进程地址空间。在Win32系统中,每个进程拥有自己的32位线性地址空间,如果一个DLL被多个进程调用,每个进程都会收到该DLL的一份映像。与16位Windows不同,在Win32中DLL可以看作是每个进程自己的代码。对于上面的这段说明,我的理解是:
(1) 16位Windows中,DLL不作为每个进程自己的代码,那么这些代码应该就是全局的了吧?这样就能用DLL 直接完成不同进程之间的通讯?
(2) DLL首先被调入 Win32系统的全局堆栈,然后映射到调用这个DLL的进程地址空间,说明内存空间中的备份是n+1份代码吗?(n为使用该DLL的进程数)