System.AppDomain类

 进程是存在独立的内存和资源的,但是AppDomain仅仅是逻辑上的一种抽象。一个process可以存在多个AppDomain。各个AppDomain之间的数据时相互独立的。一个线程可以穿梭多个AppDomain。

一、属性

ActivationContext            获取当前应用程序域的激活上下文。
ApplicationIdentity           获得应用程序域中的应用程序标识。
ApplicationTrust            获取说明授予应用程序的权限以及应用程序是否拥有允许其运行的信任级别的信息。
BaseDirectory              获取基目录,它由程序集冲突解决程序用来探测程序集。
CurrentDomain              获取当前 Thread 的当前应用程序域。
DomainManager             获得初始化应用程序域时主机提供的域管理器。
DynamicDirectory             获取目录,它由程序集冲突解决程序用来探测动态创建的程序集。
Evidence                获取与该应用程序域关联的 Evidence。
FriendlyName              获取此应用程序域的友好名称。
Id                     获得一个整数,该整数唯一标识进程中的应用程序域。
IsFullyTrusted               获取一个值,该值指示加载到当前应用程序域的程序集是否是以完全信任方式执行的。
IsHomogenous              获取一个值,该值指示当前应用程序域是否拥有一个为加载到该应用程序域的所有程序集授予的权限集。
MonitoringIsEnabled           获取或设置一个值,该值指示是否对当前进程启用应用程序域的 CPU 和内存监视。 一旦对进程启用了监视,则无法将其禁用。
MonitoringSurvivedMemorySize       获取上次完全阻止回收后保留下来的、已知由当前应用程序域引用的字节数。
MonitoringSurvivedProcessMemorySize   获取进程中所有应用程序域的上次完全阻止回收后保留下来的总字节数。
MonitoringTotalAllocatedMemorySize    获取自从创建应用程序域后由应用程序域进行的所有内存分配的总大小(以字节为单位,不扣除已回收的内存)。
MonitoringTotalProcessorTime       获取自从进程启动后所有线程在当前应用程序域中执行时所使用的总处理器时间。
PermissionSet        获取沙盒应用程序域的权限集。
RelativeSearchPath     获取基目录下的路径,在此程序集冲突解决程序应探测专用程序集。
SetupInformation     获取此实例的应用程序域配置信息。
ShadowCopyFiles     获取应用程序域是否配置为影像副本文件的指示。

public class Program
    {
        static void Main(string[] args)
        {
            AppDomain appdomain = AppDomain.CurrentDomain;      //获取当前 Thread 的当前应用程序域。
            Console.WriteLine(appdomain.Id);    //输出 1  获得一个整数,唯一标识进程中的应用程序域。
            Console.WriteLine(appdomain.ActivationContext);     //输出 空白  获取当前应用程序域的激活上下文。
            Console.WriteLine(appdomain.ApplicationIdentity);   //输出 空白 获得应用程序域中的应用程序标识。

            ApplicationTrust AT = appdomain.ApplicationTrust;   //获取说明授予应用程序的权限以及应用程序是否拥有允许其运行的信任级别的信息。
            Console.WriteLine(appdomain.ApplicationTrust);      //输出 System.Security.Policy.ApplicationTrust    

            Console.WriteLine(appdomain.BaseDirectory);         //输出 F:\xxx\xxx\ConsoleApplication1\bin\Debug\ 获取基目录,它由程序集冲突解决程序用来探测程序集。

            AppDomainManager Adm = appdomain.DomainManager;     //获得初始化应用程序域时主机提供的域管理器。
            Console.WriteLine(Adm.EntryAssembly.Location);      //输出 F:\xxx\xxx\ConsoleApplication1\bin\Debug\ConsoleApplication1.exe
            Console.WriteLine(appdomain.DomainManager);         //输出 Microsoft.VisualStudio.HostingProcess.VSHostAppDomainManager

            Console.WriteLine(appdomain.DynamicDirectory);      //输出 空白 获取目录,它由程序集冲突解决程序用来探测动态创建的程序集。

            Evidence ed = appdomain.Evidence;                   //另外一个东西了 获取与该应用程序域关联的 Evidence。
            Console.WriteLine(appdomain.Evidence.ToString());   //输出 System.Security.Policy.Evidence

            Console.WriteLine(appdomain.FriendlyName);          //输出 ConsoleApplication1.vshost.exe  获取此应用程序域的友好名称。

            Console.WriteLine(appdomain.IsFullyTrusted);        //输出 True 获取一个值,该值指示加载到当前应用程序域的程序集是否是以完全信任方式执行的。

            Console.WriteLine(appdomain.IsHomogenous);          //输出 True 获取一个值,该值指示当前应用程序域是否拥有一个为加载到该应用程序域的所有程序集授予的权限集。

            Console.WriteLine(AppDomain.MonitoringIsEnabled);   //输出 False 获取或设置一个值,该值指示是否对当前进程启用应用程序域的 CPU 和内存监视。 一旦对进程启用了监视,则无法将其禁用。

            AppDomain.MonitoringIsEnabled = true;
            //要上面那个属性启用之后,这个属性才能用
            Console.WriteLine(appdomain.MonitoringSurvivedMemorySize);  //输出 0 获取上次完全阻止回收后保留下来的、已知由当前应用程序域引用的字节数。
            Console.WriteLine(appdomain.MonitoringTotalAllocatedMemorySize);    //输出 0 获取自从创建应用程序域后由应用程序域进行的所有内存分配的总大小(以字节为单位,不扣除已回收的内存)。
            Console.WriteLine(appdomain.MonitoringTotalProcessorTime);  //输出 00:00:00 获取自从进程启动后所有线程在当前应用程序域中执行时所使用的总处理器时间。

            System.Security.PermissionSet ps = appdomain.PermissionSet;     //获取沙盒应用程序域的权限集。

            Console.WriteLine(appdomain.PermissionSet.ToString());      //输出 <PermissionSet class="System.Security.PermissionSet" version="1" Unrestricted="true"/>

            Console.WriteLine(appdomain.RelativeSearchPath);    //输出 空白

            Console.WriteLine(appdomain.SetupInformation);      //输出 AppDomainSetup 获取此实例的应用程序域配置信息。

            Console.WriteLine(appdomain.ShadowCopyFiles);       //输出 False

            File.WriteAllText(@"D:\123.txt", appdomain.PermissionSet.ToString());   

            //SetupInformation    获取此实例的应用程序域配置信息。
            //ShadowCopyFiles    获取应用程序域是否配置为影像副本文件的指示。

            Console.ReadKey();
        }
复制代码

二、方法

名称 说明
ApplyPolicy             返回应用策略后的程序集显示名称。
CreateComInstanceFrom(String, String) 创建指定 COM 类型的新实例。 形参指定文件的名称,该文件包含含有类型和类型名称的程序集。
CreateDomain(String)        使用指定的名称新建应用程序域。
CreateInstance(String, String)   创建在指定程序集中定义的指定类型的新实例。
CreateInstanceAndUnwrap(String, String) 创建指定类型的新实例。 形参指定定义类型的程序集以及类型的名称。
CreateInstanceFrom(String, String)   创建在指定程序集文件中定义的指定类型的新实例。
CreateObjRef               创建一个对象,该对象包含生成用于与远程对象进行通信的代理所需的全部相关信息。 (继承自 MarshalByRefObject。)
DefineDynamicAssembly(AssemblyName, AssemblyBuilderAccess)   以指定名称和访问模式定义动态程序集。
DoCallBack           在另一个应用程序域中执行代码,该应用程序域由指定的委托标识。
ExecuteAssembly(String)     执行指定文件中包含的程序集。
ExecuteAssemblyByName(String)     在给定其显示名称的情况下执行程序集。
GetAssemblies      获取已加载到此应用程序域的执行上下文中的程序集。
GetData         为指定名称获取存储在当前应用程序域中的值。
GetLifetimeService      检索控制此实例的生存期策略的当前生存期服务对象。 (继承自 MarshalByRefObject。)
InitializeLifetimeService   通过防止创建租约来给予 AppDomain 无限生存期。 (重写 MarshalByRefObject.InitializeLifetimeService()。)
IsCompatibilitySwitchSet  获取可以为 null 的布尔值,该值指示是否设置了任何兼容性开关,如果已设置,则指定是否设置了指定的兼容性开关。
IsDefaultAppDomain      返回一个值,指示应用程序域是否是进程的默认应用程序域。
IsFinalizingForUnload     指示此应用程序域是否正在卸载以及公共语言运行时是否正在终止该域包含的对象。
Load(AssemblyName)    在给定 AssemblyName 的情况下加载 Assembly。
ReflectionOnlyGetAssemblies   返回已加载到应用程序域的只反射上下文中的程序集。
SetData(String, Object)   为指定的应用程序域属性分配指定值。
SetData(String, Object, IPermission)   将指定值分配给指定应用程序域属性,检索该属性时要求调用方具有指定权限。
SetPrincipalPolicy      指定在此应用程序域中执行时如果线程尝试绑定到用户,用户和标识对象应如何附加到该线程。
SetThreadPrincipal     设置在以下情况下要附加到线程的默认主体对象,即当线程在此应用程序域中执行时,如果线程尝试绑定到主体这种情况。
Unload           卸载指定的应用程序域。

class Program
    {
        static void Main(string[] args)
        {
            AppDomain app = AppDomain.CreateDomain("测试程序域");    //使用指定的名称创建应用程序域
            ObjectHandle objHan = app.CreateInstance("MySpace", "MySpace.Person");  //创建指定程序集中指定的对象
            var obj = objHan.Unwrap();
            Console.WriteLine(obj.ToString());  //输出 MySpace.Person

            object obj2 = app.CreateInstanceAndUnwrap("MySpace","MySpace.Person");  //创建指定程序中指定的对象,顺带执行了Unwrap方法
            Console.WriteLine(obj2.ToString()); //输出 MySpace.Person

            ObjectHandle objHan2 = app.CreateInstanceFrom(@"D:\MySpace.dll", "MySpace.Person"); //从指定的程序集中创建类的对象
            object obj3 = objHan2.Unwrap();
            Console.WriteLine(obj3.ToString()); //输出 MySpace.Person

            //app.CreateObjRef();

            app.ExecuteAssembly(@"D:\ConsoleApplication1.exe");     //执行指定文件中包含的程序集 输出0123456789
            //D:\ConsoleApplication1.exe的代码如下
            //static void Main(string[] args)
            //{
            //    for (int i = 0; i < 10; i++)
            //    {
            //        Console.WriteLine(i);
            //    }

            //    Console.ReadKey();
            //}

            //下面改动一下D:\ConsoleApplication1.exe,改为在D盘下创建一个文件,并写入一段文字
            app.ExecuteAssembly(@"D:\ConsoleApplication1.exe");     //运行之后在D盘下创建了一个文件,并写入文字
            //static void Main(string[] args)
            //{
            //    File.WriteAllText(@"D:\AppDomainTest.txt","测试测试");
            //    Console.ReadKey();
            //}
            //注意,此次由于有Console.ReadKey(); 因此执行到这里要按两次键盘,让app程序域执行完毕才会又回到主程序域
            Assembly[] assArr = app.GetAssemblies();    //获取加载到app应用程序域中的所有程序集

            foreach (var ass in assArr)
            {
                Console.WriteLine(ass.FullName);    //诸如此类 ConsoleApplication1, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
            }

            //给定Assembly的情况下装载程序集
            app.Load("MySpace");
            Console.WriteLine(app.IsDefaultAppDomain());  //输出 False    是否是进程默认的应用程序域

            app.SetData("data1", "我靠"); //为指定的应用程序域属性分配指定值。
            object o = app.GetData("data1");
            Console.WriteLine(o.ToString());    //输出 我靠

            //ApplyPolicy    返回应用策略后的程序集显示名称。
            //CreateComInstanceFrom(String, String)    创建指定 COM 类型的新实例。 形参指定文件的名称,该文件包含含有类型和类型名称的程序集。
            //CreateObjRef    创建一个对象,该对象包含生成用于与远程对象进行通信的代理所需的全部相关信息。 (继承自 MarshalByRefObject。)
            //DefineDynamicAssembly(AssemblyName, AssemblyBuilderAccess)    以指定名称和访问模式定义动态程序集。
            //DoCallBack    在另一个应用程序域中执行代码,该应用程序域由指定的委托标识。
            //ExecuteAssemblyByName(String)    在给定其显示名称的情况下执行程序集。
            //GetLifetimeService    检索控制此实例的生存期策略的当前生存期服务对象。 (继承自 MarshalByRefObject。)
            //InitializeLifetimeService    通过防止创建租约来给予 AppDomain 无限生存期。 (重写 MarshalByRefObject.InitializeLifetimeService()。)
            //IsCompatibilitySwitchSet    获取可以为 null 的布尔值,该值指示是否设置了任何兼容性开关,如果已设置,则指定是否设置了指定的兼容性开关。
            //IsFinalizingForUnload    指示此应用程序域是否正在卸载以及公共语言运行时是否正在终止该域包含的对象。
            //ReflectionOnlyGetAssemblies    返回已加载到应用程序域的只反射上下文中的程序集。
            //SetPrincipalPolicy    指定在此应用程序域中执行时如果线程尝试绑定到用户,用户和标识对象应如何附加到该线程。
            //SetThreadPrincipal    设置在以下情况下要附加到线程的默认主体对象,即当线程在此应用程序域中执行时,如果线程尝试绑定到主体这种情况。
            //Unload    卸载指定的应用程序域。

            Console.ReadKey();
        }
    }
来自:http://www.cnblogs.com/kissdodog/archive/2013/05/09/3069553.html
时间: 2024-10-09 12:14:50

System.AppDomain类的相关文章

System.AppDomain类详解(二)

进程是存在独立的内存和资源的,但是AppDomain仅仅是逻辑上的一种抽象.一个process可以存在多个AppDomain.各个AppDomain之间的数据时相互独立的.一个线程可以穿梭多个AppDomain. 一.属性 ActivationContext 获取当前应用程序域的激活上下文.ApplicationIdentity 获得应用程序域中的应用程序标识.ApplicationTrust 获取说明授予应用程序的权限以及应用程序是否拥有允许其运行的信任级别的信息.BaseDirectory

System.AppDomain类详解(一)

AppDomain是CLR(Common Language Runtime:公共语言运行库),它可以加载Assembly.创建对象以及执行程序. AppDomain是CLR实现代码隔离的基本机制. 每一个AppDomain可以单独运行.停止:每个AppDomain都有自己默认的异常处理:一个AppDomain的运行失败不会影响到其他AppDomain的运行. CLR在被CLR Host(windows shell or InternetExplorer or SQL Server)加载后,会创建

C# AppDomain 类

/*** AppDomain 表示应用程序域,它是一个应用程序在其中执行的独立环境.无法继承此类. 应用程序域(由 AppDomain 对象表示)为执行托管代码提供隔离.卸载和安全边界. 使用应用程序域隔离可能终止进程的任务.如果正在执行任务的 AppDomain 的状态变得不稳定, 则可以卸载 AppDomain,但不会影响进程.当进程必须不重新启动而长时间运行时,这一点很重要. 还可使用应用程序域隔离不应共享数据的任务. 如果程序集被加载到默认应用程序域中,则当进程运行时将无法从内存中卸载该

System 系统类

import java.util.Arrays; import java.util.Properties; /* System 系统类 主要用于获取系统的属性数据. System类常用的方法: arraycopy(Object src, int srcPos, Object dest, int destPos, int length) 一般 src - 源数组. srcPos - 源数组中的起始位置. dest - 目标数组. destPos - 目标数据中的起始位置. length - 要复制

Java之2.System.RunTime类

1. System  系统类 主要用于获取系统的属性数据. System类常用的方法: arraycopy(Object src, int srcPos, Object dest, int destPos, int length) 一般 src - 源数组. srcPos - 源数组中的起始位置. dest - 目标数组. destPos - 目标数据中的起始位置. length - 要复制的数组元素的数量. currentTimeMillis()  获取当前系统系统.       重点 exi

反射,System.Type类

http://m.blog.csdn.net/blog/woddle/40623333 两个现实中的例子:1.B超:大家体检的时候大概都做过B超吧,B超可以透过肚皮探测到你内脏的生理情况.这是如何做到的呢?B超是B型超声波,它可以透过肚皮通过向你体内发射B型超声波,当超声波遇到内脏壁的时候就会产生一定的“回音”反射,然后把“回音”进行处理就可以显示出内脏的情况了(我不是医生也不是声学专家,不知说得是否准确^_^).2.地球内部结构:地球的内部结构大体可以分为三层:地壳.地幔和地核.地壳是固体,地

给System.Timer类的Elapsed事件加锁

背景: 最近在做一个项目,程序是命令行程序,在主程序中开一个线程,这个线程用到了System.Timer类的Elapsed事件,根据指定时间间隔循环去查询数据库,找符合条件的记录,把记录组织成xml对象发送到MSMQ中去.刚一开始的时候数据量小,在时间间隔内可以查询所有的记录并发送到MSMQ,随着业务量大增大,在时间间隔内会多次执行查询数据库发送MSMQ,这样就会产生重复的数据发送到MSMQ了.所以本次在System.Timer类的Elapsed事件中加锁,使上次任务执行完之前,后面的任务无法执

C#核编之System.Console类

顾名思义,Console类封装了基于控制台的输入输出和错误流的操作,下面列举一些System.Console类常用的成员的,这些成员能为简单的命令行程序添加一些"情趣",例如改变背景颜色和前景颜色,以各种频率发出峰鸣声.代码如下: //Console.Beep(666, 6000);//让控制台以各种频率发出峰鸣声 Console.BackgroundColor = ConsoleColor.Green;//控制台输入行的背景颜色 Console.ForegroundColor = C

System.Type类

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Reflection; namespace ConsoleApplication1 {     class Program     {         static void Main(string[] args)         {