读过金老师在《CSDN开发高手》上的《走马观花___动态链节技术概述》学到新的内容:
DLL的源起是由为了节省资源函数的共用引起的,
如A,B,两个程序中都用到了C函数,若要是在两个程序中都单独写C函数的话,既增加了工作量又增加了磁盘空间的占用,而且还增加了日后后维护的复杂程度。拿我们的操作系统来说,就说菜单,不同的浏览器如果都在自己的程序中写自己的菜单的话,那操作系统就成了个胖子了,臃肿而且占用资源。
于是,一个简单想法产生了,把C单独拿出来,然后动态的加载给A和B。有一个点提一下,通过利用已有的函数库,编写程序已演化成为以下形式:
(1)调用函数库中已有函数,
(2)开发自己的函数,
(3)将这些函数装配起来。
那么这里就是说,把C拿出来单独放置,然后在A,B运行的时候动态装配,此即动态链接。这个编译好的共享代码文件C在W i n d o w s 中被加上了D L L(Dynamic Link Library:动态链接库)后缀名,成为C.DLL这就是我们常说的DLL动态链接库文件。
由此引发三个问题:
1.我们没有调用A和B,那么把C加载到内存不就是浪费了空间吗
2.我们调用了A,已经加载了C,若要调用B时再加载C的话,浪费空间的问题还是没有解决
3.如果A/B都已经执行完毕,而C还在内存中,这.......
由此有便引发了COM的出现:COM就象一个“万能胶”,将许许多多用COM技术开发的DLL“粘” 成一个整体——这就是Windows本身。
COM的发展史:
先后出现了可以在同一网段的不同机器间动态创建对象的DCOM,
以及整合了MTS(微软事务处理器)和MSMQ(微软消息队列)等企业级信息系统功能的COM+,
到.NETFramework发布之后,微软并未完全抛弃COM+,而是在COM+基础上再包装了一层,从而使在.NET平台下COM+服务更易于使用
动态链接技术的概述:
同一份代码,在不同进程中可能会被映射到不同的地址中,这个过程是由操作系统完成的,称为动态链接地址重定位。这是COM DLL运行的基本原理。
COM 进程外服务器:将使用DLL文件共享代码的思想扩充到使用EXE文件,也可以提供类似的功能,但这时,需要访问共享功能的代码必须将自己的请求进行封装(Marshal),然后传送给另一个进程(即运行的EXE程序),这个EXE程序就被称为COM 进程外服务器
具体技术:
非MFC DLL(non-MFC DLL):在内部不使用MFC,可以被MFC或非MFC程序调用,这种DLL使用标准C接口输出函数。
标准DLL(regular DLL):在内部使用MFC,可以被MFC或非MFC程序调用,这种DLL使用标准C接口来输出函数。
MFC扩展DLL(MFC extension DLL):一般用于输出从MFC类中派生出来的新类,仅有MFC程序可以使用这种DLL。这其实将面向对象的思想应用于传统DLL的一个尝试罢了。
注册ACTIVEX DLL引起的DLL HELL:
1.A,B使用不同版本的DLL,由于安装的顺序,只保留了后一个程序安装的DLL,如果兼容性有问题的话,就会发生不可预料的后果
2.删除程序的时候不知道有多少程序在使用同一DLL,如果删除不当,会使某些程序不可使用
由于DLL HELL使得系统中的DLL垃圾越来越多,占用资源,影响系统运行速度
这是COM本身固有的缺陷(需要注册,且位置不可随意移动),这导致其退出历史舞台的必然
小资料:COM接口与COM标识
接口是对C O M 组件功能的逻辑分组,外界通过获
取特定的接口指针使用组件所提供的功能。接口声明
了一组函数,对一个组件的访问只能通过接口函数来
完成。
要访问C O M 组件的接口则必须有C O M 库的支持,
COM 库由Windows 操作系统本身提供,表现为一组Windows
A P I 函数,主要完成C O M 组件的创建、调用以及销毁等
基本功能。
COM 组件用GUID(Globally Unique Identifier)来标识,一
个G U I D 值占用了1 6 个字节,是根据计算机上的网卡地
址或用一些特殊算法生成, 可以保证全世界内唯一
性。该算法来源于开放软件基金会 ( O S F ) 的分布式计
算环境 ( D C E ) ,是关于分布式计算的一套标准。
下面是一个G U I D 的示例:
AE6105F0-4EB6-43C9-A0DA-4E2BB6EEBEF6
注意:G U I D 也称为U U I D ,即通用唯一标识符。
根据用途,又细分为以下几种G U I D :
1)用以标识组件库的G U I D 被称为L I B I D;
2)用以标识组件的G U I D 被称为类标识符C L S I D ;
3)用以标识接口的G U I D 称为I I D ;
4)P r o g I D 是程序员给某个CLSID 指定的一个友好的
名称,VB 使用P r o g I D 来标识C O M 组件,其确定方法为:
ProgID=ActiveX DLL 工程名.类模块名
.NET 下动态链接技术的发展:
1.在.NET下,所有对象的引用计数维护和销毁都由.NET Framework来负责
2..NET framework是一个全面向对象的平台,开发这个平台上的DLL库,可以完全用全OO的工具与方法进行开发
3..NET下,DLL文件的含义也发生了根本的改变__Assembly(国内一般译为程序集或装配件),它只是一个虚有的概念,并不是实在的文件
. N E T 下,DLL中的指令代码是被编译为微软中间语言(MSIL)而不是目标机器码的,
Assembly的结构是自说明的,决定它不需要注册,其好处有两点:
1.动态链接时DLL文件与具体路径无关
2.DLL组件的自说明特性,还引出一个极其强大的对象创建机制____反射(Reflection)!
3.可以在网络中分布与传送对象___.NET Remoting