标题:动态库DLL 的一些疑问
只看楼主
vfdff
Rank: 6Rank: 6
等 级:侠之大者
威 望:8
帖 子:2172
专家分:425
注 册:2005-7-15
结帖率:79.17%
 问题点数:0 回复次数:0 
动态库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的进程数)
搜索更多相关主题的帖子: DLL 注入 进程 
2008-10-10 19:47



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-237496-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.426993 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved