文本脉络图如下:

一、源代码-面向CLR的编译器-托管模块-(元数据&IL代码)中介绍了编译器将源文件编译成托管模块(中间语言和元数据),本文主要介绍如何将托管模块合并成程序集.

1、程序集的基本概念

2、程序集生成的过程

注:

(1)、清单指出程序集只有一个文件组成

(2)、对于只有一个托管模块,没有资源文件的项目,程序集就是托管模块.

(3)、如果需要将一组文件合并到程序集中可以使用程序集链接器(AL.exe)以及其他的一些命令行选项.

3、如何构建可重用、可版本控制、可保护的组件.

常用的方法是,把程序集的物理表示和逻辑表示区分开,将很少用到的类型和文件放到单独的文件中,并将这些文件作为程序集的一部分,如果运行时需要,则去下载,这样不仅节省了磁盘空间,还节省了安装时间.通过程序集,可以在不同的地方部署,同时任然将所有的文件当作一个整体来看待.

4、关于程序集自描述的优点

在程序集的模块中,还包含与引用的程序集有关的信息(版本号、描述等等),具体如下图

 

这些信息(当然远不止上图中的这点信息)使程序集能够自描述.也就是说CLR能判断为了执行程序集中的代码,程序集的直接依赖对象是什么.不需要在注册表或者Active Directory Domain Services(ADDS)中注册额外的信息.由于无需额外的信息,所以和非托管组件相比,程序集更容易部署.

5、将模块合并成程序集

程序集构成简介:

一、源代码-面向CLR的编译器-托管模块-(元数据&IL代码)中介绍了C#源码通过编译器最终生成托管模块,而托管模块是标准的32位Microsoft Windows可移植执行体(PE32)文件或者标准的64位Microsoft Windows可移植执行体(PE32+)文件。

而exe文件并不是只含有元数据的PE文件,它还是程序集.程序集是一个或多个类型定义文件及资源文件的集合,

程序集清单文件简介:

在程序集的所有文件中二、源代码=>程序集及程序集概念介绍,有一个文件容纳了清单.清单也是一个元数据表集合(关于元数据表请参考十、元数据概述),表中主要包含作为程序集组成部分的那些文件的名称,除此之外,还描述了程序集的版本、语言文化、发布者、公开导出的类型以及构成程序集的所有文件.

CLR操作的是程序集,CLR总是先加载"清单"中的数据,在根据"清单"中的数据来获取程序集中其他文件的名称.以下是程序集的重要特点

(1)、程序集定义了可重用的类型

(2)、程序集用一个版本号标记

(3)、程序集可以关联安全信息

除了包含清单元数据表的文件,程序集其他的单独文件并不具备上述特点.

类型为了进行顺利的打包、版本控制、安全保护以及使用,必须放在作为程序集一部分的模块中,程序集大多时候只有一个文件,就像前面的Program.exe文件那样,然而,程序集还可由多个文件构成,一些文件是含有元数据的PE文件,另一些是.gif文件或.jpg这样的文件,为了便于理解,可将程序集看作一个逻辑EXE或DLL.

6、Microsoft引入程序集的的原因

使用程序集将可重用类型的逻辑表示与物理表示区分开,例如,程序集可能包含多个类型,可以将常用类型放到一个文件中,不常用类型放到另一个文件中.如果程序集需要从Internet下载并部署,那么对于含有不常用类型的文件,假如客户端永远不使用那些类型,该文件就永远不会下载到客户端.

7、配置应用程序下载程序集文件

为了配置应用程序去下载程序集文件,可在应用程序配置文件中指定codeBase元素,在codeBase元素定义的URL所指向的位置,可找到程序集的所有文件.

应用程序下载程序集的过程如下:

(1)、CLR获取codeBase元素的URL

(2)、检查机器的下载缓存,判断文件是否存在.如果是,直接加载文件.如果不是,CLR去URL指向的位置将文件下载到缓存.

(3)、如果找不到文件,CLR在运行时抛出FileNotFoundException异常.

8、使用多文件程序集的三点理由

(1)、不同的类型用不同的文件,是文件能以"增量"方式下载(如Internet下载方式).另外,将类型划分到不同的文件中,可以对购买和安装的应用程序进行部分或分批打包/部署.

(2)、可在程序集中添加资源或数据文件.

例如,假定一个类型的作用是计算保险信息,需要访问精算表才能完成计算,这种情况下,不必在自己的源代码中嵌入精算表,相反,可以使用一个工具(比如稍后要讨论的程序集链接器AL.exe),是数据文件成为程序集的一部分.顺便说一句,数据文件可以为任意格式,只要应用程序知道如何解析即可.

(3)、程序集包含的各个类型可以用不同的编程语言来实现.例如,一些类型可以用C#实现,一些用VB来实现,其他则用其他语言来实现,编译用C#写的类型是,编译器会生成一个一个模块,编译用VB写的类型时,编译器也会生成另一个模块,然后使用工具将所有的模块合并成一个程序集.

好处:这样其他开发人员只知道这个程序集包含了一系列的类型信息,根本不知道、也不用知道这些类型分别是用什么语言编写的.当然可以使用ILDasm.exe获得相应的IL源代码文件。然后运行ILAsm.exe.将所有的

9、将模块还原成单个文件

(1)、对每个模块都运行ILDasm.exe,获得相应的IL源代码文件.

(2)、运行ILAsm.exe,将所有的IL源代码文件传给它.随后,ILAsm.exe会生成包含类型的单个文件.

前提:生成的IL代码足够干净.

10、关于程序集必知的重点

(1)、程序集是进行重用、版本控制和应用安全性设置的基本单元。它允许将类型

 
 

二、源代码=>程序集及程序集概念介绍的更多相关文章

  1. 【官方文档】Nginx负载均衡学习笔记(二)负载均衡基本概念介绍

    简介 负载均衡(Server Load Balancer)是将访问流量根据转发策略分发到后端多台 ECS 的流量分发控制服务.负载均衡可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应 ...

  2. C#程序集及程序集概念介绍

    一.源代码-面向CLR的编译器-托管模块-(元数据&IL代码)中介绍了编译器将源文件编译成托管模块(中间语言和元数据),本文主要介绍如何将托管模块合并成程序集. 1.程序集的基本概念 2.程序 ...

  3. java 并发多线程 锁的分类概念介绍 多线程下篇(二)

    接下来对锁的概念再次进行深入的介绍 之前反复的提到锁,通常的理解就是,锁---互斥---同步---阻塞 其实这是常用的独占锁(排它锁)的概念,也是一种简单粗暴的解决方案 抗战电影中,经常出现为了阻止日 ...

  4. 【Oracle 集群】ORACLE DATABASE 11G RAC 知识图文详细教程之集群概念介绍(一)

    集群概念介绍(一)) 白宁超 2015年7月16日 概述:写下本文档的初衷和动力,来源于上篇的<oracle基本操作手册>.oracle基本操作手册是作者研一假期对oracle基础知识学习 ...

  5. Linux LVM硬盘管理之一:概念介绍

    一.LVM概念介绍: LVM是 Logical Volume Manager(逻辑卷管理)的简写,它由Heinz Mauelshagen在Linux 2.4内核上实现.LVM将一个或多个硬盘的分区在逻 ...

  6. spring batch (一) 常见的基本的概念介绍

    SpringBatch的基本概念介绍 内容来自<Spring Batch 批处理框架>,作者:刘相. 一.配置文件 在项目中使用spring batch 需要在配置文件中声明: 事务管理器 ...

  7. Maven学习 一 概念介绍

    一 Maven是什么 Maven是一个Apache公司的开源项目,主要有两个作用:(1)是项目构建工具.(2)是用来管理java程序中jar包的依赖. 它包含了一个项目对象模型(Project Obj ...

  8. MPP、SMP、NUMA概念介绍

    一.MPP,SMP,NUMA概念介绍 1.1.       MPP架构介绍 MPP (Massively Parallel Processing),大规模并行处理系统,这样的系统是由许多松耦合的处理单 ...

  9. 转载:【Oracle 集群】RAC知识图文详细教程(一)--集群概念介绍

    文章导航 集群概念介绍(一) ORACLE集群概念和原理(二) RAC 工作原理和相关组件(三) 缓存融合技术(四) RAC 特殊问题和实战经验(五) ORACLE 11 G版本2 RAC在LINUX ...

随机推荐

  1. Java中读取.properties配置文件的通用类

    由于Java中读取配置文件的代码比较固定,所以可以将读取配置文件的那部分功能单独作为一个类,以后可以复用.为了能够达到复用的目的,不能由配置文件中每一个属性生成一个函数去读取,我们需要一种通用的方法读 ...

  2. spark 写 hbase 数据库,遇到Will not attempt to authenticate using SASL (unknown error)

    今日在windows上用spark写hbase的函数 saveAsHadoopDataset 写hbase数据库的时候,遇到Will not attempt to authenticate using ...

  3. SqlCommand和SqlDataAdapter的区别

    SqlDataAdapter对象 一.特点介绍1.表示用于填充 DataSet 和更新 SQL Server 数据库的一组数据命令和一个数据库连接.2.在SqlDataAdapter和DataSet之 ...

  4. 微软在线实验室启用谷歌的reCAPTCHA,我们又丢失了一个好东东

    在没有启用reCAPTCHA的日子,我们可以在微软的在线实验室www.microsoft.com/handsonlabs 中找到许许多多的文档.视频.动手实验环境. 不需要任何硬件.技术,就可以快速的 ...

  5. 为某金融企业的IT技术部人员提供基于TFS的软件研发流程介绍

    受莫金融企业IT信息技术部的邀请,为该金融企业的某省分公司.地市分公司的IT技术人员提供了一场基于TFS的软件研发流程的技术培训,希望可以借此提高该企业的软件研发.运维水平,同时推动企业软件研发信息化 ...

  6. mysql之使用centos7实现主从复制(读写分离)的实现过程

    什么是主从复制? 主从复制,是用来建立一个和主数据库完全一样的数据库环境,称为从数据库:主数据库一般是准实时的业务数据库. 主从复制的作用(好处)! 1.做数据的热备,作为后备数据库,主数据库服务器故 ...

  7. App.config使用方法(基础教程)

    WPF程序中的App.config文件是应用程序中经常使用的一种配置文件,System.Configuration.dll文件中提供了大量的读写的配置,是一种很高效的程序配置方式. 1.首先在工程中配 ...

  8. .NET Entity Framework (with Oracle ODP.NET)

    一.前言 1.Entity Framework是什么? Entity Framework是微软对ORM框架的实现.类似的实现也有其它方式,如DevExpress 的XPO(eXpress Persis ...

  9. f.lux在linux下的安装和使用

    安装还是蛮容易的~只是装完后在白天色温没什么变化就一直以为没有装成功 https://justgetflux.com/linux.html 这里下载,解压后 安装好以后xflux -l (经纬度) 就 ...

  10. JDK源码分析(10) CopyOnWriteArrayList

    概述 CopyOnWriteArrayList是一个线程安全集合,原理简单说就是:在保证线程安全的前提下,牺牲掉写操作的效率来保证读操作的高效.所谓CopyOnWrite就是通过复制的方式来完成对数据 ...