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