#1 加载程序集

Assembly.Load:

public class Assembly
{
public static Assembly Load(AssemblyName assemblyRef);
public static Assembly Load(String assemblyString);
}

在内部,Load导致CLR向应用程序集应用一个版本绑定重定向策略,并在GAC中查找程序集。如果传递的是一个弱命名程序集,不会应用版本绑定重定向策略,也不会去GAC中查找程序集。

AppDomain.Load:

public class AppDomain
{
public Assembly Load(String assemblyString);
}

AppDomain.Load 是一个实例方法,为了加载程序集,CLR将使用与指定AppDomain关联的设置,而不是与发出调用的那个AppDomain相关联的设置。一般要避免使用。

Assembly.LoadFrom:

public class Assembly
{
public static Assembly LoadFrom(String path);
}

在内部,AssemblyName.GetAssemblyName(String assemblyName)-->Assembly.Load(AssemblyName assemblyRef); 然后CLR应用版本绑定重定向策略。LoadFrom允许传递一个URL作为实参,例:

Assembly a = Assembly.LoadFrom(@"http://wintellect.com/SomeAssembly.dll");

Assembly.LoadFile:

public class Assembly
{
public static Assembly LoadFile(String path);
}

LoadFile可以从任意路径加载一个程序集,CLR不会自动解析任何依赖性问题。需要通过AssemblyResolve事件登记,让回调方法显示加载依赖的程序集。

Assembly.ReflectionOnlyLoadFrom & Assembly.ReflectionOnlyLoad:

public class Assembly
{
public static Assembly ReflectionOnlyLoadFrom(String assemblyFile);
public static Assembly ReflectionOnlyLoad(String assemblyString);
}

ReflectionOnlyLoadFrom加载路径指定文件,不会获取强名称,也不会再GAC和其他位置搜索文件;

ReflectionOnlyLoad会在GAC、应用程序基目录、私有路径和codebase指定位置搜索程序集,但不会应用版本控制策略。加载哪个版本,获得的就是哪个版本。CLR禁止上边两种方式加载的程序集中的任何代码执行。

仅部署一个EXE文件的做法:对于添加的DLL,将其属性中的“生成操作”更改为“嵌入的资源”。运行时,CLR找不到依赖的DLL程序集,需要做如下处理。

#2 反射的应用

发现程序集中定义的类型:

类型对象的准确含义:

c#操作符(typeof),测试精确匹配;is/as操作符,测试的是兼容匹配(可以匹配派生对象)。

构建Exception派生类的一个实例:

#3 设计支持加载项的应用程序

#4 使用反射发现类型的成员

#5 发现类型的接口

Clr Via C#读书笔记---程序集的加载和反射的更多相关文章

  1. 【C#】解析C#程序集的加载和反射

    目录结构: contents structure [+] 程序集 程序集的加载 发现程序集中的类型 反射对类型成员的常规操作 发现类型的成员 创建类型的实例 绑定句柄减少进程的内存消耗 解析自定义特性 ...

  2. .net 程序集的加载与反射

    一. 程序集的加载: 在CLR内部使用System.Reflection.Assembly类的静态LoadFrom方法尝试加载程序集. LoadFrom方法在内部调用Assembly的Load方法,将 ...

  3. clr via c# 程序集加载和反射(2)

    查看,clr via c# 程序集加载和反射(1) 8,发现类型的成员: 字段,构造器,方法,属性,事件,嵌套类型都可以作为类型成员.其包含在抽象类MemberInfo中,封装了所有类型都有的一组属性 ...

  4. clr via c# 程序集加载和反射集(一)

    1,程序集加载---弱的程序集可以加载强签名的程序集,但是不可相反.否则引用会报错!(但是,反射是没问题的) //获取当前类的Assembly Assembly.GetEntryAssembly() ...

  5. thinkphp学习笔记9—自动加载

    原文:thinkphp学习笔记9-自动加载 1.命名空间自动加载 在3.2版本中不需要手动加载类库文件,可以很方便的完成自动加载. 系统可以根据类的命名空间自动定位到类库文件,例如定义了一个类Org\ ...

  6. .net加载失败的程序集重新加载

    在.net程序中,程序集是Lazy加载的,只有在用的时候才会去加载,当程序集加载失败时,会触发AppDomain.AssemblyResolve的事件,在这个事件中,我们甚至还可以进行补救,从别得地方 ...

  7. 显示名为“xxx.XmlSerializers”的程序集未能加载到 ID 为 1 的 AppDomain 的“LoadFrom”绑定上下文中。

    VS调试程序运行中提示“显示名为“xxx.XmlSerializers”的程序集未能加载到 ID 为 1 的 AppDomain 的“LoadFrom”绑定上下文中.错误的原因为: System.IO ...

  8. Clr Via C#读书笔记---CLR寄宿和应用程序域

    #1 CLR寄宿: 开发CLR时,Microsoft实际是将他实现成包含在一个dll中的COM服务器.Microsoft为CLR定义了一个标准的COM接口,并为该接口和COM服务器分配了GUID.安装 ...

  9. CLR via C#读书笔记一:CLR的执行模型

    CLR(Common Language Runtime)公共语言进行时是一个可由多种编程语言使用的“进行时”. 将源代码编译成托管模块 可用支持CLR的任何语言创建源代码文件,然后用对应的编译器检查语 ...

随机推荐

  1. Unix操作系统中UUCP知识详细讲解

    导读 Unix操作系统有很多值得学习的地方,这里我们主要介绍Unix操作系统中的uucp,大家一起来学习下吧!UUCP系统是一组程序,完成文件传输,执行系统之间的命令,维护系统使用情况的统计,保护安全 ...

  2. Linux使用手册-vi使用手册

    vi使用手册 VI是unix上最常用的文本编辑工具,作为unix软件测试人员,有必要熟练掌握它. 进入vi的命令 vi filename :打开或新建文件,并将光标置于第一行首 vi +n filen ...

  3. 跟着百度学PHP[3]-PHP中结构嵌套之循环结构与条件结构嵌套

    任务 有个学生数组存储了学号和姓名,我们需要查找学号为"2014"的学生姓名,这时候我们就需要遍历该数组,并判定学号是否为"201 <?php $student = ...

  4. 转:SQL子句的执行顺序

    SQL 不同于与其他编程语言的最明显特征是处理代码的顺序.在大数编程语言中,代码按编码顺序被处理,但是在SQL语言中,第一个被处理的子句是FROM子句,尽管SELECT语句第一个出现,但是几乎总是最后 ...

  5. register_shutdown_function 函数详解

    设定错误和异常处理三函数 register_shutdown_function(array(‘Debug’,'fatalError’)); //定义PHP程序执行完成后执行的函数 set_error_ ...

  6. 【云计算】docker相关开源项目、工具

    十大基于Docker的开发工具 作者                     郭蕾        发布于     2014年8月19日     |              注意:QCon全球软件开发 ...

  7. 【leetcode】Word Search

    Word Search Given a 2D board and a word, find if the word exists in the grid. The word can be constr ...

  8. C#之串口

    1.字符发送 string strSend = "00 01 02 03"; serialPort1.Write(strSend); 2.字符接收 ReadDataFromSeri ...

  9. C#之显示效果

    窗体最大化(包含任务栏): this.TopMost = true; , ); this.Size = Screen.PrimaryScreen.Bounds.Size; 窗体最大化(不包含任务栏): ...

  10. 2.nodejs权威指南--Buffer

    1. Buffer 1.1 创建 var buf1 = new Buffer(100); var buf2 = new Buffer([0,1,2]); var buf3 = new Buffer(' ...