线程确实是一个好东西,可以让你可以同时作多个不同的处理。
  .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的实例作为一个参数,呵呵,有点像函数指针。