| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 683 人关注过本帖
标题:动态库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
快速回复:动态库DLL 的一些疑问
数据加载中...
 
   



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

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