日期:2009-05-31  浏览次数:20571 次

线程确实是一个好东西,可以让你可以同时作多个不同的处理。

  .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的实例作为一个参数,呵呵,有点像函数指针。