【 tulaoshi.com - ASP.NET 】
                             
                               线程确实是一个好东西,可以让你可以同时作多个不同的处理。
  .Net中新增了一个隔离层,称为应用程序域(AppDomain),它是进程内部一个逻辑独立部分。在一个进程中可以存在多个应用程序域。应用程序域可以保存一个或多个线程,就像进程一样。不同之处在于:应用程序域可以在进程内部创建,但不创建新线程。
  目前的一个问题是:线程可以跨多个应用程序域来执行,为什么?回头再看。
  好的,看看AppDomain的例子吧:appdomain.cs
using System;
public class MyAppDomain
{
 public AppDomain Domain;
 public int ThreadId;
 public void SetDomainData(string vName, string vValue)
 {
 Domain.SetData(vName, (object)vValue);
 ThreadId=AppDomain.GetCurrentThreadId();
 }
 public string GetDomainData(string name)
 {
 return (string)Domain.GetData(name);
 }
 public static void Main()
 {
 string DataName=“MyData“;
 string DataValue=“Some Data to be stored“;
 Console.WriteLine(“Retrieving current domain“);
 MyAppDomain Obj=new MyAppDomain();
 Obj.Domain=AppDomain.CurrentDomain;
 Console.WriteLine(“Setting domain data“);
 Obj.SetDomainData(DataName, DataValue);
 Console.WriteLine(“Getting domain data“);
 Console.WriteLine(“The Data found for key'“ + DataName + “'is'“ + Obj.GetDomainData(DataName) + “'running on threadid:“ + Obj.ThreadId);
 }
}
  这个不难理解,应该就是新建了一个AppDomain变量,使它引用当前Domain,所以对于Obj上Domain的引用也就相当于对当前Domain的引用。
  关键是在指定的应用程序域中执行代码,需要注意的是其两个的ThreadId都相同!!!
using System;
public class CreateAppDomains
{
 public static void Main()
 {
 AppDomain DomainA;
 DomainA=AppDomain.CreateDomain(”MyDomainA”);
 string StringA=”DomainA Value”;
 DomainA.SetData(”DomainKey”, StringA);
 CommonCallBack();
 CrosAppDomainDelegate delegateA=new CrossAppDomainDelegate(CommonCallBack);
 DomainA.DoCallBack(delegateA);
 }
 public static void CommonCallBack()
 {
 AppDomain Domain;
 Domain=AppDomain.CurrentDomain;
 Console.WriteLine(“The value'“+Domain.GetData(“DomainKey“)+“'was found in “+Domain.FriendlyName.ToString()+“running on thread id:“+AppDomain.GetCurrentThreadId().ToString());
 }
}
运行结果为:
The Value ''was found in create_appdomain.exe running on thread id: 1372
The Value 'DomainA Value' was found in MyDomainA running on thread id:1372
  写到这里,突然也明白了线程可以跨多个AppDomain访问的原因。首先这里的主程序应该是一个线程,这个应该没有问题,然后其实就是顺序执行了一个过程而已,在这个过程中,创建了一个AppDomain类然后又调用的他的方法。所以线程Id应该就是一样的。  另外就是让代码在指定的AppDomain中执行,就需要用到AppDomain的DoCallBack()方法,该方法需要使用CrossAppDomainDelegate的实例作为一个参数,呵呵,有点像函数指针。