Assembly中Load, LoadFrom, LoadFile以及AppDomain, Activator类中相应函数的区别
Assembly和AppDomain的一些关于动态加载程序集的函数有些令人头疼,但细细研究后还是可以将他们区分的。 这些函数大致可以分为四类:
第一类:加载到Load Context内
Load Context:
- Load Context是所有动态加载程序集首选应该被加载到的地方。
- 它只能加载在AppDomain信息中的ApplicationBase目录以及附带的PrivateBinPath目录内的程序集(关于这两个目录:可以参考另一篇文章:http://www.cnblogs.com/mgen/archive/2011/05/02/2034371.html)
执行这个操作的方法是:
Assembly.Load(AssemblyName)
Assembly.Load(string 程序集名称)
注意上面的字符串参数是程序集名称,而不是路径,程序集名称可以直接是简写的程序集名称,或是完整的名称比如(SampleAssembly, Version=1.0.2004.0, Culture=neutral, PublicKeyToken=8744b20f8da049e3)(不带括号)
间接调用上面方法的其他方法有:
AppDomain类
Load(AssemblyName)
Load(string 程序集名称)
ExecuteAssemblyByName(string 程序集名称)
CreateInstance(...)
Activator类
CreateInstance(...)
进行一个小测试
string assName = "mbody";
//这是程序集名称,不是路径
string pLocal = Path.Combine(Environment.CurrentDirectory, "mbody.dll");
//这是路径
var load = Assembly.Load(assName);
//用程序集名称加载
var load2 = Assembly.Load(new AssemblyName() { CodeBase = pLocal });
//用路径
Console.WriteLine(load == load2); //True
第二类:加载到LoadFrom Context内
LoadFrom Context
- 主要用来加载不在ApplicationBase目录以及附带的PrivateBinPath目录内的程序集
- 不可以指定程序集版本或其他信息
- 如果在LoadFrom Context中已经有一个具有相同程序集名称的程序集(即使实际程序集路径不一样),LoadFrom仍然会返回已经加载的程序集
执行这个操作的方法是:
Assembly.LoadFrom(string 程序集文件路径, ...)
这里的字符串参数是文件路径。
间接调用上面方法的其他方法有:
AppDomain类
CreateInstanceFrom(string 程序集文件路径, ...)
Activator类
CreateInstanceFrom(string 程序集文件路径, ...)
小测试
//这几个文件都是同一个程序集
string pLocal = Path.Combine(Environment.CurrentDirectory, "mbody.dll");
var load = Assembly.Load("mbody");
var loadFromloc = Assembly.LoadFrom(pLocal);
var loadFrom = Assembly.LoadFrom("c:\\mbody.dll");
var loadFrom2 = Assembly.LoadFrom("C:\\mbody2.dll");
Console.WriteLine(load == loadFromloc);
Console.WriteLine(loadFrom == loadFrom2);
Console.WriteLine(load == loadFrom);
//(load == loadFromLoc) != (loadFrom == loadFrom2)
第三类:反射Context
反射Context
- 这里加载的程序集不能执行,类的静态构造函数也不执行,一般用来进行反射操作。
属于这一类的方法有:
Assembly.ReflectionOnlyLoad(string 程序集名称) (byte[])
Assembly.ReflectionOnlyLoadFrom(string 程序集文件路径)
第四类:不属于任何Context
不属于任何Context
- 用来加载LoadFrom无法加载的具有相同程序集名称但是路径不同的程序集
- 可以是通过字节数组加载,也可能是Reflection.Emit生成的不在磁盘的程序集
- 具有很多的限制
属于这一类的方法有:
Assembly.Load(byte[])
Assembly.LoadFile(string 程序集文件路径)
AppDomain.ExecuteAssembly(string 程序集文件路径, ...)
测试 :
//这几个文件都是同一个程序集
string pLocal = Path.Combine(Environment.CurrentDirectory, "mbody.dll");
var load = Assembly.Load("mbody");
var loadFileloc = Assembly.LoadFrom(pLocal);
var loadFile = Assembly.LoadFile("c:\\mbody.dll");
var loadFile2 = Assembly.LoadFile("C:\\mbody2.dll");
Console.WriteLine(load == loadFileloc);
Console.WriteLine(loadFile == loadFile2);
Console.WriteLine(load == loadFile);
//(load == loadFromLoc) != (loadFrom != loadFrom2)
更多可以参考MSDN(见备注):http://msdn.microsoft.com/zh-cn/library/1009fa28.aspx
Assembly中Load, LoadFrom, LoadFile以及AppDomain, Activator类中相应函数的区别的更多相关文章
- php中strstr、strrchr、substr、stristr四个函数的区别总结
php中strstr.strrchr.substr.stristr四个函数的区别总结 投稿:junjie 字体:[增加 减小] 类型:转载 时间:2014-09-22我要评论 这篇文章主要介绍了php ...
- php中strstr、strrchr、substr、stristr四个函数用法区别
php中strstr.strrchr.substr.stristr四个函数用法区别: php中strstr strrchr substr stristr这四个字符串操作函数特别让人容易混淆,常用的是s ...
- PHP接口中的静态变量、常量与类中静态变量、常量的区别
接口: 1 不能够定义静态变量(常量除外) 2 定义的常量 const YOUCONST = VALUE,不能在子类中覆盖,在子类中以 interfaceName::YOUCONST的方式调用 3 不 ...
- 切记切记:Spring配置文件中,Component-scan无法扫描到的类中的自动装配对象无法被调用,报空指针错误。
Spring单例注入,单例对象可设置成Spring元件. 只有Spring的元件中@Autowired才有用,在普通类中@Autowired虽然不会编译报错,但运行时会报空指针错误.
- 将source类中的属性值赋给target类中对应的属性
/** * 对象的属性值拷贝 * <p> * 将source对象中的属性值赋值到target对象中的属性,属性名一样,类型一样 * <p> * example: * <p ...
- mybatis中的mapper接口文件以及selectByExample类的实例函数详解
记录分为两个部分,第一部分主要关注selectByExample类的实例函数的实现:第二部分讨论Mybatis框架下基本的实例函数. (一)selectByExample类的实例函数的实现 当你启动项 ...
- 在java中如何在非servlet的普通类中获取request、response、session
原文:http://blog.csdn.net/u012255097/article/details/53092628 在spring的普通类中: HttpServletRequest request ...
- mybatis中的mapper接口文件以及example类的实例函数以及详解
##Example example = new ##Example(); example.setOrderByClause("字段名 ASC"); //升序排列,desc为降序排列 ...
- java中的 java.util.concurrent.locks.ReentrantLock类中的lockInterruptibly()方法介绍
在java的 java.util.concurrent.locks包中,ReentrantLock类实现了lock接口,lock接口用于加锁和解锁限制,加锁后必须释放锁,其他的线程才能进入到里面执行, ...
随机推荐
- 四种对象生存期和作用域、static 用法总结
一.四种对象生存期和作用域 栈对象 隐含调用构造函数(程序中没有显式调用) 堆对象 隐含调用构造函数(程序中没有显式调用),要显式释放 全局对象.静态全局对象 全局对象的构造先于main函数 已初始化 ...
- Spark in meituan http://tech.meituan.com/spark-in-meituan.html
Spark在美团的实践 忽略元数据末尾 回到原数据开始处 引言:Spark美团系列终于凑成三部曲了,Spark很强大应用很广泛, 文中Spark交互式开发平台和作业ETL模板的设计都很有启发借鉴意义. ...
- RPC服务框架dubbo(五):dubbo-admin和dubbo-monitor的安装
一.安装dubbo-admin 去这里 http://download.csdn.net/download/u013081610/10044744 下载dubbo-admin.war 部署dubbo- ...
- PCH简单介绍
https://wenku.baidu.com/view/3c9c5f190a4e767f5acfa1c7aa00b52acfc79cb0.html
- 简明 Vim 练级攻略(转,有些动态图不能显示,请看转载处)
vim的学习曲线相当的大(参看各种文本编辑器的学习曲线),所以,如果你一开始看到的是一大堆VIM的命令分类,你一定会对这个编辑器失去兴趣的.下面的文章翻译自<Learn Vim Progress ...
- linux 流量控制全攻略(TC)
TC很是强大啊,很多所谓的硬件路由器,都是基于这个做的. TC介绍 在linux中,TC有二种控制方法CBQ和HTB.HTB是设计用来替换CBQ的.它是一个层次式的过滤框架.TC包括三个基本的构成块: ...
- redis 做为缓存服务器 注项!
作为缓存服务器,如果不加以限制内存的话,就很有可能出现将整台服务器内存都耗光的情况,可以在redis的配置文件里面设置: # maxmemory <bytes> #限定最多使用1.5GB内 ...
- 【sql绕过】Bypass waf notepad of def
文章是通过阅读<[独家连载]我的WafBypass之道 (SQL注入篇)>写的阅读笔记. Waf的类型 1.云waf云waf通常是CDN包含的waf,DNS在解析的时候要解析到cdn上面制 ...
- HDFS的实现机制
参考以上这张图,实际上我们客户端访问HDFS里面的内容时,并不需要真实知道内容存在于服务器的内容的真实路径,我们只需要知道一个虚拟路径就可以,比如最上面的hdfs://weekend110:9000/ ...
- SAN和NAS的区别: 层次不一样
SAN : STORAGE AREA NETWORK 存储区域网络 NAS : NETWORK ATTACHED STORAGE 网络附加存储 NAS不一定是盘阵,一台普通的主机就可以做出NAS, ...