AppDomain 类

表示应用程序域,它是一个应用程序在其中执行的独立环境。 此类不能被继承。

命名空间:   System
程序集:  mscorlib(位于 mscorlib.dll)

System.Object
  System.MarshalByRefObject
    System.AppDomain
[ClassInterfaceAttribute(ClassInterfaceType.None)]
[ComVisibleAttribute(true)]
public sealed class AppDomain : MarshalByRefObject, _AppDomain,
IEvidenceFactory
属性

 
 
名称 说明
ActivationContext

获取当前应用程序域的激活上下文。

ApplicationIdentity

获得应用程序域中的应用程序标识。

ApplicationTrust

获取说明授予应用程序的权限以及应用程序是否拥有允许其运行的信任级别的信息。

BaseDirectory

获取基目录,它由程序集冲突解决程序用来探测程序集。

CurrentDomain

获取当前 Thread 的当前应用程序域。

DomainManager

获得初始化应用程序域时主机提供的域管理器。

DynamicDirectory

获取目录,它由程序集冲突解决程序用来探测动态创建的程序集。

Evidence

获取与该应用程序域关联的 Evidence

FriendlyName

获取此应用程序域的友好名称。

Id

获得一个整数,该整数唯一标识进程中的应用程序域。

IsFullyTrusted

获取一个值,该值指示加载到当前应用程序域的程序集是否是以完全信任方式执行的。

IsHomogenous

获取一个值,该值指示当前应用程序域是否拥有一个为加载到该应用程序域的所有程序集授予的权限集。

MonitoringIsEnabled

获取或设置一个值,该值指示是否对当前进程启用应用程序域的 CPU 和内存监视。 一旦对进程启用了监视,则无法将其禁用。

MonitoringSurvivedMemorySize

获取上次回收后保留下来的,已知由当前应用程序域引用的字节数。

MonitoringSurvivedProcessMemorySize

获取进程中所有应用程序域的上次回收后保留下来的总字节数。

MonitoringTotalAllocatedMemorySize

获取自从创建应用程序域后由应用程序域进行的所有内存分配的总大小(以字节为单位,不扣除已回收的内存)。

MonitoringTotalProcessorTime

获取自从进程启动后所有线程在当前应用程序域中执行时所使用的总处理器时间。

PermissionSet

获取沙盒应用程序域的权限集。

RelativeSearchPath

获取基目录下的路径,在此程序集冲突解决程序应探测专用程序集。

SetupInformation

获取此实例的应用程序域配置信息。

ShadowCopyFiles

获取应用程序域是否配置为影像副本文件的指示。

方法

 
 
名称 说明
AppendPrivatePath(String)

已过时。 将指定的目录名追加到专用路径列表。

ApplyPolicy(String)

返回应用策略后的程序集显示名称。

ClearPrivatePath()

已过时。 将指定专用程序集位置的路径重置为空字符串 ("")。

ClearShadowCopyPath()

已过时。 将包含影像复制的程序集的目录列表重置为空字符串 ("")。

CreateComInstanceFrom(String, String)

创建指定 COM 类型的新实例。 形参指定文件的名称,该文件包含含有类型和类型名称的程序集。

CreateComInstanceFrom(String, String, Byte[], AssemblyHashAlgorithm)

创建指定 COM 类型的新实例。 形参指定文件的名称,该文件包含含有类型和类型名称的程序集。

CreateDomain(String)

使用指定的名称新建应用程序域。

CreateDomain(String, Evidence)

使用所提供的证据创建具有给定名称的新应用程序域。

CreateDomain(String, Evidence, AppDomainSetup)

使用指定的名称、证据和应用程序域设置信息创建新的应用程序域。

CreateDomain(String, Evidence, AppDomainSetup, PermissionSet, StrongName[])

使用指定的名称、证据、应用程序域设置信息、默认权限集和一组完全受信任的程序集创建新的应用程序域。

CreateDomain(String, Evidence, String, String, Boolean)

使用证据、应用程序基路径、相对搜索路径和指定是否向应用程序域中加载程序集的影像副本的形参创建具有给定名称的新应用程序域。

CreateDomain(String, Evidence, String, String, Boolean, AppDomainInitializer, String[])

使用证据、应用程序基路径、相对搜索路径和指定是否向应用程序域中加载程序集的影像副本的形参创建具有给定名称的新应用程序域。 指定在初始化应用程序域时调用的回调方法,以及传递回调方法的字符串实参数组。

CreateInstance(String, String)

创建在指定程序集中定义的指定类型的新实例。

CreateInstance(String, String, Object[])

创建在指定程序集中定义的指定类型的新实例。 形参指定激活特性数组。

CreateInstanceAndUnwrap(String, String)

创建指定类型的新实例。 形参指定定义类型的程序集以及类型的名称。

CreateInstanceAndUnwrap(String, String, Object[])

创建指定类型的新实例。 形参指定定义类型的程序集、类型的名称和激活特性的数组。

CreateInstanceFrom(String, String)

创建在指定程序集文件中定义的指定类型的新实例。

CreateInstanceFrom(String, String, Boolean, BindingFlags, Binder, Object[], CultureInfo, Object[])

创建在指定程序集文件中定义的指定类型的新实例。

CreateInstanceFrom(String, String, Boolean, BindingFlags, Binder, Object[], CultureInfo, Object[], Evidence)

已过时。 创建在指定程序集文件中定义的指定类型的新实例。

CreateInstanceFrom(String, String, Object[])

创建在指定程序集文件中定义的指定类型的新实例。

CreateInstanceFromAndUnwrap(String, String)

创建在指定程序集文件中定义的指定类型的新实例。

CreateInstanceFromAndUnwrap(String, String, Boolean, BindingFlags, Binder, Object[], CultureInfo, Object[])

创建在指定的程序集文件中定义的指定类型的新实例,指定是否忽略类型名称的大小写,并指定绑定特性和用于选择要创建的类型的联编程序、构造函数的自变量、区域性以及激活特性。

CreateInstanceFromAndUnwrap(String, String, Boolean, BindingFlags, Binder, Object[], CultureInfo, Object[], Evidence)

已过时。 创建在指定程序集文件中定义的指定类型的新实例。

CreateInstanceFromAndUnwrap(String, String, Object[])

创建在指定程序集文件中定义的指定类型的新实例。

CreateObjRef(Type)

创建包含所有生成代理用于与远程对象进行通信所需的相关信息的对象。(继承自 MarshalByRefObject。)

ExecuteAssembly(String, String[])

使用指定的自变量执行指定文件中包含的程序集。

ExecuteAssembly(String, String[], Byte[], AssemblyHashAlgorithm)

使用指定的自变量、哈希值和哈希算法执行指定文件中包含的程序集。

ExecuteAssemblyByName(AssemblyName, Evidence, String[])

已过时。 根据给定的 AssemblyName 使用指定的证据和实参执行程序集。

ExecuteAssemblyByName(AssemblyName, String[])

根据给定的 AssemblyName 使用指定的参数执行程序集。

ExecuteAssemblyByName(String)

在给定其显示名称的情况下执行程序集。

ExecuteAssemblyByName(String, String[])

在给定显示名称的情况下,使用指定自变量执行程序集。

GetAssemblies()

获取已加载到此应用程序域的执行上下文中的程序集。

GetData(String)

为指定名称获取存储在当前应用程序域中的值。

GetHashCode()

作为默认哈希函数。(继承自 Object。)

GetLifetimeService()

检索当前生存期服务对象,用于控制此实例的生存期策略。(继承自 MarshalByRefObject。)

GetType()

获取当前实例的类型。

InitializeLifetimeService()

通过防止创建租约来给予 AppDomain 无限生存期。(覆盖 MarshalByRefObject.InitializeLifetimeService()。)

IsCompatibilitySwitchSet(String)

获取可以为 null 的布尔值,该值指示是否设置了任何兼容性开关,如果已设置,则指定是否设置了指定的兼容性开关。

IsDefaultAppDomain()

返回一个值,指示应用程序域是否是进程的默认应用程序域。

IsFinalizingForUnload()

指示此应用程序域是否正在卸载以及公共语言运行时是否正在终止该域包含的对象。

Load(AssemblyName)

在给定 AssemblyName 的情况下加载 Assembly

Load(Byte[])

加载带有基于通用对象文件格式 (COFF) 的图像的 Assembly,该图像包含已发出的 Assembly

Load(Byte[], Byte[])

加载带有基于通用对象文件格式 (COFF) 的图像的Assembly,该图像包含已发出的 Assembly。 还加载表示 Assembly 的符号的原始字节。

Load(String)

在给定其显示名称的情况下加载 Assembly

ReflectionOnlyGetAssemblies()

返回已加载到应用程序域的只反射上下文中的程序集。

SetData(String, Object)

为指定的应用程序域属性分配指定值。

SetData(String, Object, IPermission)

将指定值分配给指定应用程序域属性,检索该属性时要求调用方具有指定权限。

SetPrincipalPolicy(PrincipalPolicy)

指定在此应用程序域中执行时如果线程尝试绑定到用户,用户和标识对象应如何附加到该线程。

SetThreadPrincipal(IPrincipal)

设置在以下情况下要附加到线程的默认主体对象,即当线程在此应用程序域中执行时,如果线程尝试绑定到主体这种情况。

ToString()

获取一个字符串表示,包含应用程序域友好名称和任意上下文策略。(覆盖 Object.ToString()。)

Unload(AppDomain)

卸载指定的应用程序域。

事件

 
 
名称 说明
AssemblyLoad

在加载程序集时发生。

AssemblyResolve

在对程序集的解析失败时发生。

DomainUnload

在即将卸载 AppDomain 时发生。

FirstChanceException

当托管代码抛出异常时发生,在运行时在调用堆栈中搜索应用程序域中的异常处理程序之前。

ProcessExit

当默认应用程序域的父进程退出时发生。

ReflectionOnlyAssemblyResolve

当程序集的解析在仅限反射的上下文中失败时发生。

ResourceResolve

当资源解析因资源不是程序集中的有效链接资源或嵌入资源而失败时发生。

TypeResolve

在对类型的解析失败时发生。

UnhandledException

当某个异常未被捕获时出现。

 
 
备注

 
 

应用程序域,由表示AppDomain对象,帮助提供有关执行托管的代码的隔离、 卸载和安全边界。

  • 使用应用程序域隔离可能会终止进程的任务。 如果状态AppDomain,正在执行的任务变得不稳定,AppDomain可以而不会影响进程中卸载。 进程必须运行很长一段无需重新启动时,这很重要。 你还可以使用应用程序域隔离不应共享数据的任务。

  • 如果程序集被加载到默认应用程序域,它无法从内存中卸载过程运行时。 但是,如果您打开第二个应用程序域加载和执行程序集,程序集是卸载卸载该应用程序域时。 使用此方法最大程度减少偶尔使用大型 Dll 的长时间运行进程的工作集。

多个应用程序域可以运行在一个进程中;但是,没有应用程序域和线程之间的一对一的相关性。 多个线程可以属于单个应用程序域,并且单个应用程序域中时的给定的线程并不局限于单个应用程序域,在任何给定时间,执行线程。

使用创建应用程序域CreateDomain方法。 AppDomain实例用于加载和执行程序集 (Assembly)。 当AppDomain是不再在使用中,可以将它卸载。

AppDomain类实现的一组启用应用程序进行响应时加载的程序集,应用程序域将被卸载,或引发未经处理的异常时的事件。

有关使用应用程序域的详细信息,请参阅应用程序域

此类实现MarshalByRefObject, _AppDomain,和IEvidenceFactory接口。

决不要创建的远程操作包装AppDomain对象。 这样可以将发布到的远程引用AppDomain,如公开方法CreateInstance与远程访问和有效地销毁该的代码访问安全性AppDomain。 恶意客户端连接到远程AppDomain无法获取任何资源的访问权限AppDomain本身具有访问权限。 不创建任何扩展的类型的远程操作包装MarshalByRefObject并实现恶意客户端无法用于绕过安全系统的方法。

小心

默认值为AppDomainSetup.DisallowCodeDownload属性是false。 此设置是不安全的服务。 若要防止服务下载部分受信任的代码,请将此属性设置为true

示例

 
 

此示例演示如何创建一个新AppDomain,新实例化中的一个类型AppDomain,以及与该类型的对象通信。 此外,此示例演示如何卸载AppDomain导致要进行垃圾回收的对象。

using System;
using System.Reflection;
using System.Threading; class Module1
{
public static void Main()
{
// Get and display the friendly name of the default AppDomain.
string callingDomainName = Thread.GetDomain().FriendlyName;
Console.WriteLine(callingDomainName); // Get and display the full name of the EXE assembly.
string exeAssembly = Assembly.GetEntryAssembly().FullName;
Console.WriteLine(exeAssembly); // Construct and initialize settings for a second AppDomain.
AppDomainSetup ads = new AppDomainSetup();
ads.ApplicationBase = AppDomain.CurrentDomain.BaseDirectory; ads.DisallowBindingRedirects = false;
ads.DisallowCodeDownload = true;
ads.ConfigurationFile =
AppDomain.CurrentDomain.SetupInformation.ConfigurationFile; // Create the second AppDomain.
AppDomain ad2 = AppDomain.CreateDomain("AD #2", null, ads); // Create an instance of MarshalbyRefType in the second AppDomain.
// A proxy to the object is returned.
MarshalByRefType mbrt =
(MarshalByRefType) ad2.CreateInstanceAndUnwrap(
exeAssembly,
typeof(MarshalByRefType).FullName
); // Call a method on the object via the proxy, passing the
// default AppDomain's friendly name in as a parameter.
mbrt.SomeMethod(callingDomainName); // Unload the second AppDomain. This deletes its object and
// invalidates the proxy object.
AppDomain.Unload(ad2);
try
{
// Call the method again. Note that this time it fails
// because the second AppDomain was unloaded.
mbrt.SomeMethod(callingDomainName);
Console.WriteLine("Sucessful call.");
}
catch(AppDomainUnloadedException)
{
Console.WriteLine("Failed call; this is expected.");
}
}
} // Because this class is derived from MarshalByRefObject, a proxy
// to a MarshalByRefType object can be returned across an AppDomain
// boundary.
public class MarshalByRefType : MarshalByRefObject
{
// Call this method via a proxy.
public void SomeMethod(string callingDomainName)
{
// Get this AppDomain's settings and display some of them.
AppDomainSetup ads = AppDomain.CurrentDomain.SetupInformation;
Console.WriteLine("AppName={0}, AppBase={1}, ConfigFile={2}",
ads.ApplicationName,
ads.ApplicationBase,
ads.ConfigurationFile
); // Display the name of the calling AppDomain and the name
// of the second domain.
// NOTE: The application's thread has transitioned between
// AppDomains.
Console.WriteLine("Calling from '{0}' to '{1}'.",
callingDomainName,
Thread.GetDomain().FriendlyName
);
}
} /* This code produces output similar to the following: AppDomainX.exe
AppDomainX, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
AppName=, AppBase=C:\AppDomain\bin, ConfigFile=C:\AppDomain\bin\AppDomainX.exe.config
Calling from 'AppDomainX.exe' to 'AD #2'.
Failed call; this is expected.
*/
 

此类型的所有公共静态(Visual Basic 中的 已共享 在 Visual Basic 中)成员都是线程安全的。不保证所有实例成员都是线程安全的。

 
更多:
 

.Net AppDomain详解(二)的更多相关文章

  1. .NET DLL 保护措施详解(二)关于性能的测试

    先说结果: 加了缓存的结果与C#原生代码差异不大了 我对三种方式进行了测试: 第一种,每次调用均动态编译 第二种,缓存编译好的对象 第三种,直接调用原生C#代码 .net dll保护系列 ------ ...

  2. PopUpWindow使用详解(二)——进阶及答疑

      相关文章:1.<PopUpWindow使用详解(一)——基本使用>2.<PopUpWindow使用详解(二)——进阶及答疑> 上篇为大家基本讲述了有关PopupWindow ...

  3. Android 布局学习之——Layout(布局)详解二(常见布局和布局参数)

    [Android布局学习系列]   1.Android 布局学习之——Layout(布局)详解一   2.Android 布局学习之——Layout(布局)详解二(常见布局和布局参数)   3.And ...

  4. logback -- 配置详解 -- 二 -- <appender>

    附: logback.xml实例 logback -- 配置详解 -- 一 -- <configuration>及子节点 logback -- 配置详解 -- 二 -- <appen ...

  5. 爬虫入门之urllib库详解(二)

    爬虫入门之urllib库详解(二) 1 urllib模块 urllib模块是一个运用于URL的包 urllib.request用于访问和读取URLS urllib.error包括了所有urllib.r ...

  6. [转]文件IO详解(二)---文件描述符(fd)和inode号的关系

    原文:https://www.cnblogs.com/frank-yxs/p/5925563.html 文件IO详解(二)---文件描述符(fd)和inode号的关系 ---------------- ...

  7. Android View 的绘制流程之 Layout 和 Draw 过程详解 (二)

    View 的绘制系列文章: Android View 的绘制流程之 Measure 过程详解 (一) Android View 绘制流程之 DecorView 与 ViewRootImpl 在上一篇  ...

  8. HTTPS详解二:SSL / TLS 工作原理和详细握手过程

    HTTPS 详解一:附带最精美详尽的 HTTPS 原理图 HTTPS详解二:SSL / TLS 工作原理和详细握手过程 在上篇文章HTTPS详解一中,我已经为大家介绍了 HTTPS 的详细原理和通信流 ...

  9. Linux dts 设备树详解(二) 动手编写设备树dts

    Linux dts 设备树详解(一) 基础知识 Linux dts 设备树详解(二) 动手编写设备树dts 文章目录 前言 硬件结构 设备树dts文件 前言 在简单了解概念之后,我们可以开始尝试写一个 ...

随机推荐

  1. JS实现数组去重(重复的元素只保留一个)

    1.遍历数组法 它是最简单的数组去重方法(indexOf方法) 实现思路:新建一个数组,遍历去要重的数组,当值不在新数组的时候(indexOf为-1)就加入该新数组中: ,,,,,,,,]; func ...

  2. OCM_第四天课程:Section2 —》GC 的安装和配置

    注:本文为原著(其内容来自 腾科教育培训课堂).阅读本文注意事项如下: 1:所有文章的转载请标注本文出处. 2:本文非本人不得用于商业用途.违者将承当相应法律责任. 3:该系列文章目录列表: 一:&l ...

  3. java 对象锁学习

    机制 锁机制是用来解决多线程共享资源时产生的冲突问题的.java 为每一个对象关联一个对象锁,通常把锁分为对象锁和类锁,他们的本质都是对象锁,只不过对象锁关联的是类的 Object 对象 (java. ...

  4. vue渲染时对象里面的对象的属性提示undefined,但渲染成功

    场景: 从后台请求的数据结构如下: 我的list是对象,而comment又是list里的对象,渲染成功了,却报如下错: 解决办法: 添加一个:v-if

  5. ERP发货系统的修改(四十三)

    产品添加批号后相应修改产品库存表中对应批次产品的数量: /// <summary> /// 产品添加批号后相应修改产品库存表中对应批次产品的数量 /// </summary> ...

  6. Codeforces 327E Axis Walking 状压dp

    这题真的有2500分吗... 难以置信... #include<bits/stdc++.h> #define LL long long #define fi first #define s ...

  7. 2n皇后问题【dfs】

    <题目链接> 题目描述 给定一个n*n的棋盘,棋盘中有一些位置不能放皇后.现在要向棋盘中放入n个黑皇后和n个白皇后,使任意的两个黑皇后都不在同一行.同一列或同一条对角线上,任意的两个白皇后 ...

  8. 001.网络TCP/IP工程知识点

    一 互联网概述 计算机网络定义:由自主计算机互连起来的集合体. 计算机网络两大部分:硬件:计算机.通信设备.接口设备和传输介质. 软件:通信协议和应用软件. 广域网拓扑结构通常有:网状拓扑结构和环形拓 ...

  9. serialVersionUID 序列化

    http://www.mkyong.com/java-best-practices/understand-the-serialversionuid/ 简单来说,Java的序列化机制是通过在运行时判断类 ...

  10. Codeforces.567E.President and Roads(最短路 Dijkstra)

    题目链接 \(Description\) 给定一张有向图,求哪些边一定在最短路上.对于不一定在最短路上的边,输出最少需要将其边权改变多少,才能使其一定在最短路上(边权必须为正,若仍不行输出NO). \ ...