快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

.NET对软件安装的冲击



.NET对软件安装的冲击

什么是.NET?

.NET是如何改变整个软件安装的?
.NET改变了我们进行软件安装的许多方法。最明显的,我们有了新的语言C#。还有,操作系统也发生了微妙的变化,以及它处理共享代码的方法。

关于元数据(Metadata)
首先,你必须了解什么是Managed Code?所有基于微软中间语言(MSIL)的代码都是以Managed Code运行的。比如.NET推出的新语言C#就完全是以Managed Code运行的。而其他Visual Studio .NET附带的语言,比如Visual C++,答应Managed Code 和None-managed Code 混合使用。
那么Managed Code 有什么特点呢?它与None-Managed Code 的最大区别就是包含了元数据(Metadata)。元数据描述了代码里的每一个元素,答应.NET的运行库对其进行治理,并使得代码可以自描述(Self-Describing)。.NET运行库通过使用元数据来提供诸如内存治理、跨语言集成、代码安全和对象生命周期自动控制等等服务。简朴的说,Managed Code就是可以与.NET运行库以“契约合作”的方法运行的代码。
元数据可以包括assemblies、可装载文件、类型、方式等等。与制作安装关系最为密切的就是assembly manifest了。Assembly是一个程序的主要组成部分,包括了所有的功能、版本信息,并作为一个整体进行发布。每一个Assembly都要包括一个assembly manifest,并使得assembly 可以自描述。Manifest包括:

以文本表示的assembly 标识、版本等,假如要与别程序共享,还要包括数字签名。
描述包括的文件
指定assembly的类型和资源,并指明该assembly输出哪些。
列举所有依靠的assembly。
指明运行需要的许可权限
Manifest里也包括了以前是由自注册(Self-Registration)来完成的数据。比如所有的类型信息存放在Manifest里,这些Manifest数据又都放在.DLL或.EXE文件里。这样通过Manifest我们就可以很轻易的知道Managed Code 的相互依靠关系,而不会漏掉任何信息。但是,假如是Managed Code 和None-Managed Code的混合情况,就不是那么轻易做到了。
假如没有一种新的安装技术出现,开发者将面临一个大难题。

对自安装(Self-Installing)代码的误解
其中一个就是,使用Managed Code编写的软件不需要安装。因为一些安装的任务已经由元数据完成了,比如COM组件的注册。只要把程序的所有文件拷贝到一个目录下面,就可以直接运行了。很遗憾,这并不是软件安装的全部过程。
软件安装并不是简朴的把文件从位置A拷贝到位置B。软件安装程序应该是给用户提供一个友好的、可靠的和统一的方法,把软件安装到用户的机器上面。首先,安装程序需要通过一个统一的认识的用户界面,让用户选择安装的选项,然后创建文件夹、快捷方法,进行升级、网络安装,还有许可证治理等等。在上面的例子里,你无法为用户完成所有这些事情,更不用说许可证治理了。
另外,Managed Code 和None-managed Code混合的应用程序也不能自安装。而且,要安装这样的程序比安装纯粹的None-managed Code 还要麻烦。我们不可能一下子全部丢掉以前的代码,全部转成Managed Code 。所以,我们不得不认真的考虑这个问题。

Isolated Applications and Side-by-Side Components
在Windows XP和.NET平台里,微软提供了一套机制来减少DLL Hell的发生。我们知道,应用程序一般都依靠于一些共享资源,所谓共享,就是说假如已经有一个资源安装在了系统上,应用程序就不再需要安装该资源了,直接使用就可以了。于是DLL Hell就这样发生了,假如一个应用程序需要一个比系统上现有的共享资源版本更高的资源,于是它以新的高版本的资源代替了老版本。而且有这样的可能,新版本的资源并不能与老版本的资源相兼容。而系统中只能存在该资源的一个版本,所以依靠于老版本资源的应用程序将崩溃!

为了解决这个问题,微软提供了两种方式:Isolated Applications 和Side-by-Side Components。
Isolated Application 就是让应用程序在发布的时候,附带了该程序所有组件的隔离版本(Isolated Version),这样就不会受其他安装程序影响了。但是这需要完全重写代码,代价太高。
Side-by-Side组件就是可以在新旧版本的共享资源一起共存的环境中运行。Windows XP中的许多共享资源就是以Side-by-Side的方法来编写的。开发者可以通过使用编写Application Manifest来达到Side-by-Side 的好处。Application Manifest描述了程序所依靠的组件的版本信息,所以操作系统可以根据这些信息来装载准确的共享资源。比如应用程序是在COMCTL32的V5上进行开发的,并在Application Manifest里指明了依靠于COMCTL32的V5版本。现在,即使系统上存在有别的版本的COMCTL32,操作系统也仍将为该程序装载V5版本的资源。

…..





返回类别: 教程
上一教程: Microsoft .NET 框架常见问题 (二)
下一教程: 使用CodeDom开发基于B/S的.NET+MSSQL代码生成器的随感

您可以阅读与".NET对软件安装的冲击"相关的教程:
· .net手机软件开发(六)OBEX应用??文件传输部分
· .net中一些所封装的类
· 把.NET程序部署到没有安装.NET Framwork的机器上
· .net下软件的自动升级--上传
· 新iNet软件使微软.Net服务能够支持Java
    微笑服务 优质保证 索取样品