注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

天涯倦客的博客

祝福你朋友永远快乐!

 
 
 

日志

 
 

浅谈C#应用程序域  

2011-01-25 12:52:02|  分类: C# |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

在以前传统的开发中我们都知道,一个应用程序对应一个进程,并为该进程指定虚拟内存,由操作系统来映射实际的物理内存,有效的维护了进程之间的安全性。但另一方面,每一个进程都会消耗一定的系统资源,降低了性能,并且进程间的通信也比较麻烦。

在.NET中推出了一个新的概念:C#应用程序域(AppDomain)。可以理解成很多应用程序域都可以运行在同一个.NET的进程中,可以降低系统消耗,同时不同的域之间互相隔离,在安全性方面有保障。另外对于同一个进程内不同域之间的通信也相对简单一点。

应用程序域涉及的内容很多,本文就简要描述以下两个方面:
1、如何创建、卸载域
2、如何实现域间的通信

一、如何创建、卸载域

在.NET中提供了AppDomain类为执行托管代码提供隔离、卸载和安全边界。

AppDomainSetup info = new AppDomainSetup();  info.LoaderOptimization = LoaderOptimization.SingleDomain;   AppDomain domain = AppDomain.CreateDomain("MyDomain", null, info);  domain.ExecuteAssembly("C:\\test\\DomainCom.exe");  AppDomain.Unload(domain); 1、使用AppDomainSetup类定义新域的属性,比如可以设置应用程序的根目录,设置被加载程序的类别。
例子中使用的是SingleDomain表示加载程序不得在C#应用程序域之间共享内部资源,还可以使用MultiDomain、MultiDomainHost等其他属性

2、在第四行创建一个名字为MyDomain的新域

3、在第5行在新域内部执行一个应用程序

4、第6行卸载这个新域
通过这样创建后,新域的执行就算出现系统异常也不会影响到原来域的执行,那么就可以做类似WatchDog(监控子程序,一旦退出就重启)的程序了

二、如何实现域间的通信

公共语言运行库禁止在不同域中的对象之间进行直接调用,但我们可以复制这些对象,或通过代理访问这些对象

AppDomainSetupinfo2=newAppDomainSetup();  info2.LoaderOptimization=LoaderOptimization.SingleDomain;  info2.ApplicationBase="C:\\test";  AppDomainAppDomaindomain2=AppDomain.CreateDomain("MyDomain2",null,info2);  ObjectHandleobjHandle=domain2.CreateInstance("DomainCom","DomainCom.TestStatic");  ICollectionobj=objHandle.Unwrap()asICollection;  inti=obj.Count;  domain2.ExecuteAssembly("C:\\test\\DomainCom.exe");  AppDomain.Unload(domain2); 开始的代码都差不多,重点是以下几个方面:

1、第5行在新域中创建一个对象(类DomainCom.TestStatic),并返回一个代理ObjectHandle 类用于在多个C#应用程序域之间传递对象
DomainCom.TestStatic必须从MarshalByRefObject类继承,为了演示方便,这个类很简单,从ICollection接口继承,就实现了一个Count属性:

usingSystem;  usingSystem.Collections.Generic;  usingSystem.Text;  usingSystem.Collections;   namespaceDomainCom  {  publicclassTestStatic:MarshalByRefObject,ICollection  {  privatestaticintcount=1;   publicintCount  {  get  {  countcount=count*2;  returncount;  }  }   未实现代码#region未实现代码  publicboolIsSynchronized{get{thrownewNotImplementedException();}}   publicobjectSyncRoot{get{thrownewNotImplementedException();}}   publicvoidCopyTo(Arrayarray,intindex)  {  thrownewNotImplementedException();  }  publicIEnumeratorGetEnumerator()  {  thrownewNotImplementedException();  }  #endregion  }  }  2、第6行取得新域中的对象

3、在第七在当前域中给新域中的对象赋值

4、第8行执行新域中的应用程序,这个应用程序中就是弹出一个对话框显示Count的值。


摘自红色黑客联盟(www.7747.net) 原文:http://www.7747.net/kf/201007/52734.html

  评论这张
 
阅读(707)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017