Assembly.Load动态加载程序集而不占用文件 z
2015-08-09 19:15
459 查看
方式一:占用文件的加载
Assembly assembly = Assembly.Load(path);
用上面的方法可以动态的加载到dll,但是用这种方法加载到的dll一直到程序运行结束都是占用的dll文件,在此期间不能够对dll文件进行升级,或者修改.
方式二:不占用文件的方式
Assembly ab = Assembly.Load(File.ReadAllBytes(path));
首先把dll加载到内存中,然后在在加载成Assembly ,这样的话,dll完全跟程序解耦了,只要加载完成,你就是把dll给删除了,程序也一样照常运行。
有时候,需要将被引用的程序集放到单独的目录统一维护(如更新等),提供给多个项目使用到这些程序集。
我们知道,项目在添加了对程序集的引用后,编译时通常会将引用的程序集一起生成到bin或release目录。现在为了统一管理,我们把这些要引用的程序 集放到一个公共的目录,供多个项目使用,同时我们移除掉bin或release目录下的这些dll文件。默认情况下,程序运行过程中需要加载一个程序集, 会先后从系统目录和程序运行目录查找要加载的dll文件,如果都没有查找到,将会抛出一个异 常:System.IO.FileNotFoundException: 未能加载文件或程序集“Accessibility, Version=x.x.x.x, Culture=neutral, PublicKeyToken=xxxxxx”或它的某一个依赖项。系统找不到指定的文件。
现在我们通过注册AppDomain.CurrentDomain.AssemblyResolve事件,在事件处理程序中根据args.Name和我们指定的目录重新构建dll文件路径,加载程序集并返回。这样实现在程序集加载不成功的情况下,转到我们指定的目录加载程序集。
以下代码即实现运行时控制从指定路径加载dll:
static void Main(string[] args)
{
AppDomain.CurrentDomain.AssemblyResolve += CurrentDomain_AssemblyResolve;
}
static Assembly CurrentDomain_AssemblyResolve(object sender, ResolveEventArgs args)
{
string module = new AssemblyName(args.Name).Name;
string dll = Path.Combine("d:\\AssemblyDir",string.Format("{0}.dll",module));
return Assembly.LoadFrom(dll);
}
Assembly assembly = Assembly.Load(path);
用上面的方法可以动态的加载到dll,但是用这种方法加载到的dll一直到程序运行结束都是占用的dll文件,在此期间不能够对dll文件进行升级,或者修改.
方式二:不占用文件的方式
Assembly ab = Assembly.Load(File.ReadAllBytes(path));
首先把dll加载到内存中,然后在在加载成Assembly ,这样的话,dll完全跟程序解耦了,只要加载完成,你就是把dll给删除了,程序也一样照常运行。
有时候,需要将被引用的程序集放到单独的目录统一维护(如更新等),提供给多个项目使用到这些程序集。
我们知道,项目在添加了对程序集的引用后,编译时通常会将引用的程序集一起生成到bin或release目录。现在为了统一管理,我们把这些要引用的程序 集放到一个公共的目录,供多个项目使用,同时我们移除掉bin或release目录下的这些dll文件。默认情况下,程序运行过程中需要加载一个程序集, 会先后从系统目录和程序运行目录查找要加载的dll文件,如果都没有查找到,将会抛出一个异 常:System.IO.FileNotFoundException: 未能加载文件或程序集“Accessibility, Version=x.x.x.x, Culture=neutral, PublicKeyToken=xxxxxx”或它的某一个依赖项。系统找不到指定的文件。
现在我们通过注册AppDomain.CurrentDomain.AssemblyResolve事件,在事件处理程序中根据args.Name和我们指定的目录重新构建dll文件路径,加载程序集并返回。这样实现在程序集加载不成功的情况下,转到我们指定的目录加载程序集。
以下代码即实现运行时控制从指定路径加载dll:
static void Main(string[] args)
{
AppDomain.CurrentDomain.AssemblyResolve += CurrentDomain_AssemblyResolve;
}
static Assembly CurrentDomain_AssemblyResolve(object sender, ResolveEventArgs args)
{
string module = new AssemblyName(args.Name).Name;
string dll = Path.Combine("d:\\AssemblyDir",string.Format("{0}.dll",module));
return Assembly.LoadFrom(dll);
}
相关文章推荐
- 如何让自己安心学习
- [转]在Arcmap中加载互联网地图资源的4种方法
- iOS开发--提交应用Your binary is not optimized for iPhone 5
- 黑马程序员---oc block
- bat的变量与命令set的用法
- TCP如何区分已连接套接字和已请求连接字
- android语音聊天
- springmvc+mongodb+maven 项目测试代码
- 数据结构-----栈
- 小小喷气机 v1.1 安卓最新版
- IE兼容性汇总
- Leetcode #113 Path Sum II
- SDNU 1040.导弹拦截【NOIP1999】【8月9】
- K近邻算法
- matlab:启动后无法调用工具包
- Leetcode: Max Points on a Line
- HDU1429 胜利大逃亡
- poj 2299树状数组求逆序数
- 老版本上的兼容ripple效果以及通用selecter
- Objective-C学习笔记_类的扩展