技术只有在交流分享中才能更上一层楼! 复杂的事简单做。 简单的事认真做。 认真的事重复做。 重复的事创造性做。

Assembly、CLR、GAC

上一篇 / 下一篇  2008-05-10 11:03:27 / 个人分类:软件开发相关

0h `)K ]-nC0assembly程序集51Testing软件测试网1y[$Pdc1LZ
51Testing软件测试网Q/r]-Sq6MB]i_
assembly是构成一个逻辑单元的一个或多个文件的集合。在这里的“文件”通常是指托管模块,但程序51Testing软件测试网)A Era%sL7R [%V;{
集也能包含其他的文件。大部分程序集只包含一个文件,但是程序集能够而且有时确实包含多个文件。51Testing软件测试网b,K?-\n4f!f'r
组成多个文件程序集的所有文件必须位于相同的目录下。当使用C#编译器生成简单的EXE文件时,这个51Testing软件测试网)u:]:d.W;K0g
EXE文件时,这个EXE文件不仅仅是托管模块,它同时也是程序集。大多数编译器可以生成非程序集的模51Testing软件测试网'l$i5c iUc_e
块,也能够向自己创建的程序集添加其他文件。.net框架SDK还提供了一个名为AL(程序集连接器)的
yuZR$Z0工具,它可以将文件联接成程序集。
4Ni!WC6^5LTJ0
nub(H+_Ige8FB0多文件程序集通常用于将用不同语言编写的模块相结合,或将托管模块同包含JPEG或其他资源的普通文
M[9PsM#j0件相结合。多文件程序集还被用来将应用程序划分为可下载的单元,这对部署在Internet上的代码十分
]XH)t!T3NG2_0有用。
P+r:f V Gk9C r)b0
uvb?;a/Rk@CY&Y0CLR是如何知道那些文件属于一个程序集?在程序集中的一个文件中包含一个清单(manifest)从物理角51Testing软件测试网eb6?|8c
度,清单只是增加的元数据;当编译器生成托管模块,而该托管模块又碰巧是程序集的时候,它将清单写
])X!a,F(x0入模块的元数据之内。从逻辑的角度而言,清单是程序集内容的路径图。它最重要的元素有以下几种51Testing软件测试网U.w,~v4u&U6F
程序集的名称51Testing软件测试网:N9@-z[$D@
程序集中其他文件的列表
g^l[#J g D{ Iiq0从程序集的其他文件中导出的数据类型的列表,和将这些数据类型映射到定义它们的文件的信息51Testing软件测试网qalNM^/I
版本号,格式为:主版本号.次版本号.内部版本号.修订号
hI4Y3`'[U051Testing软件测试网__p[gi0HCi5F
清单还包括其他信息,例如公司名称、描述、安全许可和区域性字符串。后者对程序集的目标国别进行51Testing软件测试网6UG:MM^"M
界定(如en-US 表示美式英语)并且通常与所谓的“附属程序集”一起使用。描述一个由3个托管模块51Testing软件测试网#L\G2aP0U
和一个JPEG文件组成的多文件程序集。Main.exe文件包含清单,清单包括对其他文件的引用。从文件系
$]-Iw6cf}G:T0统角度考虑,这些文件仍然是独立的文件。但是对于CLR,它们是一个逻辑实体。
\~*RsS~I\051Testing软件测试网sQ2a1GKO0pb6O
如果缺少指示程序集要完成什么操作信息,编译器默认生成弱名称的程序集。“弱名称”意味着程序没
[*sy:~qq T(F2I0有经过加密签名,CLR只使用程序集清单中存储的名称(不包括扩展名的程序集文件名)表示程序集。但51Testing软件测试网1P W.}Bsy-k
程序集可以具有强名称。强名称程序集包含出版者的公匙和数字签名(公匙所在的程序集清单的散列)
:~-`9LL?:^0
}&p4NP)y]2B`0数字签名通过出版者私匙生成并由公匙确认。强名称程序集的表示源于程序集名称、公匙、版本号和区51Testing软件测试网H/w#v"g| [iz
域性字符串。不论多小的差异,都足以区别两个不同的程序集。
af.]ui-G+S051Testing软件测试网a2O@d~`%r
SDK的AL实用工具能用来创建强名称程序集。大多数语言编译器,包括C#和Visual Basic .NET编译器51Testing软件测试网.{ |b)mc
,也能创建强名称程序集。是部署弱名称程序集还是强名称程序集取决于你,你可以根据程序集的目标51Testing软件测试网!qMkG3th w\
应用来确定。如果要将程序集部署在全局程序集缓存GAC中——放置可供多个应用程序公享的程序集的
ub'U Y Q7W0全局仓库,那么一定要使用强名称程序集。
Pw9kXWM0
r']2oL8hX0如果希望进行版本检查,也需要对程序集使用强名称。当CLR加载弱名称的程序集时,它不进行版本检查
[0aJ!Uw;`o0——当你用新版本替换旧版本的程序集(也许新版本修订了旧版本中的某些错误时,并且希望使用该程51Testing软件测试网*EHxp'tim C
序的应用程序集的应用程序能够自动使用更新的程序集,这一点很有利。但是,当你针对某个版本的程
J%^z"xUA@0序集仔细地测试了应用程序后,有人又用某个可能存在缺陷的程序集替换了旧版本的程序集,这样很糟51Testing软件测试网\?#H3~oiSP G
糕。这是Windows开发者经常遇到的“DLL地狱”。强名称可以解决这个问题。当CLR加载强名称程序集时51Testing软件测试网m'Ei)vr
,它会将程序集中的版本号同应用程序加载的版本号进行对照(该信息被记录在模块的元数据当中)如
}ua@L{ B1vT y0果版本号不匹配,CLR会引发异常
s9Ba)aK+K'M9o0
w Nc#G7N:BO0当然严格的版本检查也有它自己的缺陷。如果你决定使用强名称,但后来在程序集中发现一个错误。你
y,_;Wc8JUc0更正了错误并部署已修正的程序集。但是,使用该程序集的应用程序不加载新版本的程序集,除非你重
6CXv1v*D[p8LMHr0建应用程序。而且如果你删除旧版本,应用程序根本就不运行。解决方法是修改CLR绑定策略。管理员51Testing软件测试网7{!wu _z+Zr-XoemT*@
可以通过编辑配置文件将CLR指向新版本的强名称程序集。当然,如果新版本有问题,你就又碰上了麻
|@]Axx1E}9{C0烦了,这就是为什么不要随便授予别人管理员特权。51Testing软件测试网;b)}fonti_ W+z
51Testing软件测试网&d\A"T*k)^Dz
操作程序集听起来很复杂,当然,又些时候是这样,幸运的是,如果不需要创建共享程序集或者链接到51Testing软件测试网c^ kk!y
其他程序集(除了FCL之外,它是一组共享程序集)的程序集,大部分关于命名和绑定的问题就不需要
ci[)A*Kr0考虑。你所做的是启动编译器,把程序集复制到指定目录,然后运行。

Kl9O@VhoE6o#f&o051Testing软件测试网 w7w(f n7?

基本概念
;r0lP+a!{Y _F0
?)S1h-dce0托管模块(Managed Module)51Testing软件测试网mLn"m&n.j

&P1i8|&}5X:@G~8\:vbH0托管模块是一个需要CLR才能执行的标准Windows可移植可执行(portable executable,简称PE)文件。51Testing软件测试网;L|p.y){&d&@W

F4Nxq2L0元数据(Metadata)51Testing软件测试网"o:Xkkl

'Ko A w4V3r$Bf0简单的讲,元数据就是一个数据表的集合,在这些表中,其中一些用于描述托管模块中所定义的内容(比如所定义的类型和它们的成员),另外还有一些用于描述托管模块中所引用的内容(比如被引用的类型和它们的成员)。
dTq4@lnb*c0
be-G%\/Y0URL: ms-help://MS.MSDNQTR.2004APR.1033/cpguide/html/cpconmetadataoverview.htm
,dO1^CW0
C-~gXOo)A9e7WA:s0程序集清单(Assembly Manifest)51Testing软件测试网#CMm?1O)YUS$C]
51Testing软件测试网;ljnfPJK3X^
程序集清单是另外一些元数据表的集合。这些表描述了组成程序集的文件,程序集所有文件中实现的公有导出类型,以及一些程序集相关的资源文件或数据文件。
)@J4X9Qk'G^+\'Q6u0
([6u(E7w9i+D0ms-help://MS.MSDNQTR.2004APR.1033/cpguide/html/cpconAssemblyManifest.htm51Testing软件测试网A!dV S _'kv;[

0a?cHr-c sHQ0
X:Pmm0k2NB D0E01.程序集(Assembly)的概念:
5B K"LR{^ h];_0
!ga4d xr0首先:程序集是一个或多个托管模块,以及一些资源文件的逻辑组合。因为它是一个逻辑上的组合,所以程序集的逻辑表示和物理表示可以相互分离。如何将代码和资源划分到不同的文件中完全取决于我们。例如,我们可以将一些很少使用的类型或资源放在一个单独的Assembly Module中,然后根据需要(比如第一次用到的时候),从web上下载它们。如果没有用到,它们将不会被下载。这样既节省磁盘空间,也减少了安装时间。程序集允许我们将文件的部署分解开来,同时又将所有的文件看作一个单独的集合。
Z` TJ,g0}051Testing软件测试网9y&L? E5_r+}
    其次:因为CLR是直接和程序集打交道的,所以程序集也是组件复用,以及实施安全策略和版本策略的最小单元(安全策略,版本信息等都只能是加在程序集上)。
(? HW6^ |N\_0
5q\|.Uo7O0注意:程序集是一个逻辑组合,它可以包含很多个文件。大多数程序集(比如使用Visual Studio.NET创建的那些)一般都是单文件程序集,也就是只有一个.exe或者.dll文件(目前.NET的程序集只有这两种格式)。在这种情况下,程序集清单(manifest)直接嵌入到单文件程序集中。但是,你也可以用“程序集生成工具”(Al.exe)来创建多文件程序集。也可以只创建一个只包含清单的程序集。 
qT*j;|(Xg Hj-C051Testing软件测试网w|8u*YO:`Z&N
51Testing软件测试网B[)?z N?~5D*Ky!n
2.强命名程序集(Strong Name Assembly)的概念
;D/Kt(],tK}z4p0
:V7g x(G5I \*Q,W$f0因为不同的公司可能会开发出有相同名字的程序集来,如果这些程序集都被复制到同一个相同的目录下,最后一个安装的程序集将会代替前面的程序集。这就是著名的Windows “DLL Hell”出现的原因。
#_K1B.aJ J5WNb051Testing软件测试网w:j`-J#s
很明显,简单的用文件名来区分程序集是不够的,CLR需要支持某种机制来唯一的标识一个程序集。这就是所谓的强命名程序集。51Testing软件测试网 FIUmPUr6{:}hV
51Testing软件测试网5~Z9Tk}3J6HAD
一个强命名程序集包含四个唯一标志程序集的特性:文件名(没有扩展名),版本号,语言文化信息(如果有的话),公有秘钥。51Testing软件测试网r1U"@p"yO5r!~?

%PKU-t(aX+G,N0这些信息存储在程序集的清单(manifest)中。清单包含了程序集的元数据,并嵌入在程序集的某个文件中。
#h$E+@u C3o0
\P\H"M"w0下面的字符串标识了四个不同的程序集文件:51Testing软件测试网1zv2KV8t3rj
51Testing软件测试网.|zr@(GVH
“MyType, Version=1.0.1.0, Culture=neutral, PublicKeyToken=bf5779af662fc055”
)W'c R{&m4s4Ge6M0
#rbokA @?F0“MyType, Version=1.0.1.0, Culture=en-us, PublicKeyToken=bf5779af662fc055”
&}w9kk)^bj}L0
C$n]+x2j+m `8T%o0“MyType, Version=1.0.2.0, Culture=neturl, PublicKeyToken=bf5779af662fc055”51Testing软件测试网#d%CN)YI B
51Testing软件测试网Fz6s3CF6p4m,Nu)T4{
“MyType, Version=1.0.2.0, Culture=neutral, PublicKeyToken=dbe4120289f9fd8a”
&fu+t*p%mn0
8D pw8I#{.]%a!jz0如果一个公司想唯一的标识它的程序集,那么它必须首先获取一个公钥/私钥对,然后将共有秘钥和程序集相关联。不存在两个两个公司有同样的公钥/私钥对的情况,正是这种区分使得我们可以创建有着相同名称,版本和语言文化信息的程序集,而不引起任何冲突。
%kw ab*H0
(s.s.eC4@Gao"T051Testing软件测试网 p:\]%j vfd[;{^t
    与强命名程序集对应的就是所谓的弱命名程序集。(其实就是普通的没有被强命名的程序集)。两种程序集在结构上是相同的。都使用相同的PE文件格式,PE表头,CLR表头,元数据,以及清单(manifest)。二者之间真正的区别在于:强命名程序集有一个发布者的公钥/私钥对签名,其中的公钥/私钥对唯一的标识了程序集的发布者。利用公钥/私钥对,我们可以对程序集进行唯一性识别、实施安全策略和版本控制策略,这种唯一标识程序集的能力使得应用程序在试图绑定一个强命名程序集时,CLR能够实施某些“已确知安全”的策略(比如只信任某个公司的程序集)。
JPtLP0
6]H#Ywl2~:E9g:_,M051Testing软件测试网UW7BJkzA1K^
3. 如何创建强命名程序集(Strong Name Assembly)51Testing软件测试网W6i0s,w-[w1W8D o{"l
51Testing软件测试网 DWan-F5BZ+u Rc
创建一个强命名程序集首先需要获得一个用强命名实用工具(Strong Name Utility,即SN.exe,.NET SDK自带)产生的密钥。
G"mS/@+coYr9a-_051Testing软件测试网!Q2{4[&WtA xj
下面简要介绍一下SN.exe的一些用法。
]1iZsx ]U051Testing软件测试网d}8OkT
要产生一个公钥/私钥对:51Testing软件测试网})U%JSGY?l@
51Testing软件测试网7x;}"S.B4~A
a) SN –k MyCompany.Keys51Testing软件测试网T5DbEH!g%d
51Testing软件测试网/NL7M)`ha!` B
该命名告诉SN.exe创建一个名为MyCompany.keys的文件。MyCompany.keys文件将包含以对以二进制格式存储的公有密钥和私有密钥。
f5@ Pe$N#o}"@~;q0
Epw7e\a qO }&Y0b)查看公有密钥:51Testing软件测试网g~r/aqS

r'[ O eqq U@V4B0首先生成一个只包含公有密钥的文件:
7J)D8A B.b*F2h4X!Wv051Testing软件测试网`C-}-]rQ q
SN –p MyCompany.keys MyCompany.PublicKey
#i p%|3k6OT2BA051Testing软件测试网+g2|@'q1p)Gh6?7W
然后用-tp参数查看:SN –tp MyCompany.PublicKeys51Testing软件测试网tD2Cvu%W
51Testing软件测试网 d `xQ'X
Public key is
+DTIBBf1t+O051Testing软件测试网I#dr`2B;Y)Qn
0024000004800000940000000602000000240000525341310004000001000100bb7214723ffc13
9?7v&h X5nY.i7h C0
+ll)bYkuXa0901343df4b9c464ebf7ef4312b0ae4d31db04a99673e8163768cc0a2a7062e731dbeb83b869f05
&M YFy\"y\b0
8HDt0k_)l d}009bf8009e90db5c8728e840e782d2cf928dae35c2578ec55f0d11665a30b37f8636c08789976d8
5Ca4k ]w zB051Testing软件测试网 M.k_,LB ^X
ee9fe9a5c4a0435f0821738e51d6bdd6e6711a5acb620018658cce93df37d7e85f9a0104a5845051Testing软件测试网?dWHQZ8To1vW

5Q F9Zj&^i6H{S"S053995ce851Testing软件测试网/|-e ? \%K

"ReQ.iW%Ds051Testing软件测试网d9{ D-` T4^?
Public key token is 2dc940d5439468c2
$wIr#JaC051Testing软件测试网7]'H sAtP
创建好了公钥/私钥对,创建强命名程序集就很容易了。只需要把System.Reflection.AssemblyKeyFileAttribute特性加入到源代码中就可以了: [assembly:AssemblyKeyFile("MyCompany.keys")]
5J;r$y4F]lBj#D(@0
/E3Jox7dTA5i+zQ051Testing软件测试网Pzi S/gN-d
说明:公钥/私钥对文件的扩展名可以是任意的(也可以没有),因为编译的时候都是以元数据的格式读取的。51Testing软件测试网QU$SGfK B
51Testing软件测试网4Yali{\
51Testing软件测试网*t7A)m'k ?[+x
4. 程序集的部署方式51Testing软件测试网s.U5fk vU
51Testing软件测试网%OtB#Y5a+Sv[a
一个程序集有两种部署方式:51Testing软件测试网 z#~,k"[B'q+B}#i
51Testing软件测试网aE8hU3GZV$y&\1i3i
a) 私有方式51Testing软件测试网&n-T-Fx:Ccp i

/d+z p*xv&oeey|0和应用程序部署在同一目录下的程序集称作私有部署程序集。弱命名程序集只能进行私有部署。51Testing软件测试网Vpl~%_#S }q!g4]/u

GS@,?`(o#|/Bn&nyH)i0b)全局方式51Testing软件测试网?~8Kn4t B

a3MK.r,Tff#v0全局部署方式将程序集部署在一些CLR已确知的地方,当CLR搜索程序集时,它会知道到这些地方去找。强命名程序集既可以进行私有部署,也可以进行全局部署。51Testing软件测试网3^VRfmnR@
51Testing软件测试网t"|QtT*g*XH

程序集种类
是否可以进行私有部署
是否可以进行全局部署
普通程序集
强命名程序集
51Testing软件测试网 d^)a$o8BZ$D)I

.H5D r J$ZI}@5F05.如何部署强命名程序集(Strong Name Assembly)和GAC
Z!s ` J:md%l?d&|lc0
wObB)D3pH&J0a)GAC的概念51Testing软件测试网"VT&\s/o~XR{

P7F X%ol]Ij0如果一个Assembly要被多个应用程序访问,那么他就必须放在一个CLR已确知的目录下,并且CLR在探测到有对该Assembly的引用时,它必须能自动到该目录下寻找这个程序集。这个已确知的目录称作GAC(Global Assembly Cache),就是全局程序集缓存。它一般位于下面的目录下::\Windows\Assembly\GAC。
j4@C:o#t?Qr,R"Aq0OQ0
'^5H j0Y3Vws3}C0GAC的作用就是提供给CLR一个已知的确定的目录去寻找引用的程序集。
](iE6G? [051Testing软件测试网'z+vv"Un*D Xm{]

V$e6iVo7W#d]hza0b) GAC的内部结构
&~ad.n#e%O*Fk K%}0
3MFp6Q4B4y3E0GAC是一个特殊的结构化的目录,用Windows Explorer浏览你会以为它只是一个包含很多程序集的普通目录。其实不是这样的,在命令行下查看,你会发现它实际上包含很多子目录,子目录的名字和程序集的名称是相同的,但它们都不是实际的程序集,实际的程序集位于程序集名对应的目录下。比如进入GCFWK子目录,我们会发现其中又有很多的子目录。51Testing软件测试网W'[ A ]}c-gN

6G W7H P t0

&or4d0` pu051Testing软件测试网/meA9n8D

机器内每一个安装到GAC的GCFWK.dll在GCFWK中都会有一个子目录。这里只有一个目录表明只有一个版本的GCFWK程序集被安装。实际的程序集保存在每一个对应的版本目录下。目录的名称以下划线的形式分割为“(Version)_(Culture)_(PublicKeyToken)”。
1w#j%r:Z/`/I1w051Testing软件测试网zn8d5e _%Hp3\u,e
GCFWK的语言文化信息为netture,就表示为1.0.0.0__bf5779af662fc055”。
z9ob&G5T"w051Testing软件测试网}:D ~&b3D0zQ"|){'kd
表示得意义是:51Testing软件测试网Vw0]_XN#L1LD2?]
51Testing软件测试网@,L-y o.ps5D
“GCFWK, Version=1.0.0.0, Culture=neutral, PublicKeyToken=bf5779af662fc055”51Testing软件测试网 xz*g d~6vk/?
51Testing软件测试网_x.sa Z X
如果语言文化信息为”ja”,就表示为”1.0.0.0_ja_bf5779af662fc055”51Testing软件测试网 E2E-NP#H$A"mN
51Testing软件测试网%E.zS Y[ B5F y r
表示得意义是:51Testing软件测试网Y9nvc1O!~F%nEl

l } q](Z(ta _0“GCFWK, Version=1.0.0.0, Culture=ja, PublicKeyToken=bf5779af662fc055”51Testing软件测试网q| v.]Y+G%p$`"xw5g
51Testing软件测试网/`,B)CL W5hS(^M2Mlx;i0U
?c)部署强命名程序集到GAC
7{{P zkC@051Testing软件测试网4Fa$Wu/c3\-pt
GAC包含很多子目录,这些子目录是用一种算法来产生的,我们最好不要手动将程序集拷贝到GAC中,相反,我们应使用工具来完成这样的工作。因为这些工具知道GAC的内部结构J51Testing软件测试网5o d)htT5V"|}'dk
51Testing软件测试网&n} pC xF D'wK-_V,[
在开发和测试中,最常用的工具就是GACUtil.exe。51Testing软件测试网)E{ _4Q's9D

jWO ^5J Rh0在GAC中注册程序集跟COM注册差不多,但相对更容易:51Testing软件测试网b-L6L-BF7UYL(]7`8i9f

zU8L:P4~8ejN,d01.把程序集添加到GAC中:51Testing软件测试网4e6?` `l&yUR
GACUtil /i sample.dll
+\N n,hFL0(参数/i是安装的意思)51Testing软件测试网qf@0F,p

.}+k`eU9_6XL02.把程序集移出GAC51Testing软件测试网 n6A9DS.\` W$x2H

.B9iC4@-e#e({,\J4q0GACUtil /u sample.dll
4},H,X,x K/sMXN0(参数/u就移除的意思)
5}Wb)\uF"{051Testing软件测试网*C7R;[8z$\q6E
注意:不能将一个弱命名程序集安装到GAC中。51Testing软件测试网i$m(S tOt

P8A,Jb(L]nhy(u+G0如果你试图把弱命名程序集加入到GAC中,会收到错误信息:” Failure adding assembly to the cache: Attempt to install an assembly without a strong name”51Testing软件测试网B*m/q.bRPm
51Testing软件测试网8Z3hXT"fBJ&}A/b,l

&ZV4h~1J2b7C-s?L0d) 强命名程序集的私有部署
i\s.{T)P0
e^6X+X%c|!op3GH,]E0把程序集安装到GAC有几个好处。首先,GAC使得很多程序可以共享程序集,这从整体上减少了使用的物理内存;其次,我们很容易将一个新版的程序集部署到GAC中,并通过一种发布者策略(差不多就是一种重定向方法,比如将原来引用版本为1.0.0.0程序集的程序,通过更改它的配置文件,转而让程序去引用版本为2.0.0.0的程序集)来使用新版本;最后,GAC还提供了对不同版本程序集的并存(side-by-side)管理方式。但是,GAC的安全策略通常只允许管理员更改,同时,向GAC中安装程序集也破坏了.NET框架的简单拷贝部署的许诺。51Testing软件测试网Z9Y QW:j

,k+REU sn!A7O0除了向GAC或者以私有部署方式部署强命名程序集之外,我们还可以将强命名程序集部署在仅为一小部分程序知道的某个任意目录下。配置每一个应用程序的XML配置文件,让它们指向一个公有目录,这样,在运行时,CLR将知道到哪里去找这个强命名程序集。但这样又有可能会引发”DLL Hell”的问题,因为没有哪个程序可以控制这个程序集何时被卸载。这在.NET中也是不被鼓励的。
{)U+sJ)H0z bI[051Testing软件测试网Z X0Mk syM E8e}

_/w8?qU ^06.并行执行(Side - By - Side)51Testing软件测试网+NW p3gB.R~ ^
51Testing软件测试网4W#^B*^#E5M
这里是一个强命名程序集的例子:
w5|+Ry~(j p7o{q%r0
!j:|Ba:J d\Cd0首先有一个App.exe程序集,它绑定这一个版本为2.0.0.0的Calculus.dll程序集和一个版本为3.0.0.0的AdvMath.dll程序集。而AdvMath.dll程序集同时又绑定着一个版本为1.0.0.0的Calculus.dll的程序集。如下图:51Testing软件测试网'G5K~ x:Q M3K:DxT
51Testing软件测试网M8QP(DRly

6?Q B`%BL:}0k2a0

w \e V!} q;{W0An application that requires different versions of the Calculus.dll assembly51Testing软件测试网3V@Q;Ak}i`
51Testing软件测试网3H5j3icS@,E`
    CLR能够将名程相同但路径不同的多个文件加载到同一个地址空间,这在.NET中称为并存执行(Side-By-Side)执行,它是解决Windows中”DLL Hole”问题的关键技术51Testing软件测试网'_ayD1G|

IM Q E$s:^#S0   如.NET Framework 1.0 和.NET Framework 1.1都可以同是在一台机器上运行,这用到的就是并存执行(Side-By-Side)执行。51Testing软件测试网zx*s*[&\L5m~r

w @uoVx T0更多参考:
:K+N9L9uLC P7T$s \0
(Y{!YI8Y/B0ms-help://MS.MSDNQTR.2004APR.1033/cpguide/html/cpconSide-by-SideExecutionTop.htm
p jj7X5jC'|051Testing软件测试网Tc e#R+? K*d
http://www.microsoft.com/china/msdn/archives/library/dnnetdep/html/sidexsidenet.asp51Testing软件测试网4P^dwu2J ?A,W
51Testing软件测试网$G0D4T)c@6M({ A

x9W A)h$Dr07. CLR如何解析类型引用
(ka9~!@/Ie,Aw0
pghN&_^|v-G M-V0CLR在解析一个被引用的类型时,它可以在以下三个地方的其中之一找到该类型:51Testing软件测试网}wOUS

e I^y)Ra[1wO0· 同一个文件51Testing软件测试网 e%F{6N w{1Y

{H~#bt)R0对同一个文件中类型的访问在编译时就已经确定下来了,CRL直接从该文件中加载被引用的类型。完成加载后,程序将继续运行。
ymu$w#{eE6}051Testing软件测试网iM_O lb
·不同的文件,相同的程序集51Testing软件测试网p"z1q6U$\Q
51Testing软件测试网&~ nIW I
CLR首先确保被引用的文件在当前程序集清单中的FileDef表内。CLR然后会在加载程序集清单文件的目录中查找被引用的文件。该文件被加载的同时,CLR会检查它的散列值以确保文件的完整性,之后便会找到相应的类型成员。完成加载后,程序将继续运行。
;\Lq'zW051Testing软件测试网}[n/a e!U h
·不同的文件,不同的程序集51Testing软件测试网![.LPCM&\
51Testing软件测试网AF e+T }2` u
当被引用的程序集在一个不同的程序集文件中时,CLR会首先加载包含被引用程序集的清单所在的文件。如果该文件没有包含所需要的类型,CLR会根据此清单文件加载适当的文件。这样也会找到相应类型的成员。完成加载后,程序将继续运行。51Testing软件测试网!et4wn?7g7T
51Testing软件测试网 y&_p#I,a6o V6qN
       如果在解析类型引用的过程中出现任何错误,比如文件找不到,文件不能被加载,散列值不匹配等等,系统将会抛出相应的异常。
2^I0Y5s1^O051Testing软件测试网/N%wS"e5^
下图演示了类型的绑定过程:51Testing软件测试网;ZlC?Wgi f&C T~

"k@/\Z YNx051Testing软件测试网 qHe}%q mB7X

On oX R'z)`-x ~0

程序集种类
是否可以引用命名程序集
是否可以引用命名程序集
普通程序集
强命名程序集
51Testing软件测试网:Zj-Kd"k\ }

51Testing软件测试网!K-RH}7pf C;Gs

 51Testing软件测试网']:{;X%T(j8I-^Y


TAG: assembly CLR GAC 软件开发相关

 

评分:0

我来说两句

日历

« 2024-05-31  
   1234
567891011
12131415161718
19202122232425
262728293031 

数据统计

  • 访问量: 22252
  • 日志数: 36
  • 文件数: 1
  • 建立时间: 2007-11-13
  • 更新时间: 2008-09-21

RSS订阅

Open Toolbar