System.Type.GetConstructorImpl 方法
方法描述
当在派生类中重写时,使用指定的绑定约束和指定的调用约定搜索其参数与指定的参数类型和修饰符匹配的构造函数。
语法定义(C# System.Type.GetConstructorImpl 方法 的用法)
protected abstract ConstructorInfo GetConstructorImpl( BindingFlags bindingAttr, Binder binder, CallingConventions callConvention, Type[] types, ParameterModifier[] modifiers )
参数/返回值
参数值/返回值 | 参数类型/返回类型 | 参数描述/返回描述 |
---|---|---|
bindingAttr | System-Reflection-BindingFlags | 一个位屏蔽,由一个或多个指定搜索执行方式的 BindingFlags 组成。- 或 -零,以返回 null。 |
binder | System-Reflection-Binder | 一个对象,该对象定义一组属性并启用绑定,而绑定可能涉及选择重载方法、强制参数类型和通过反射调用成员。- 或 -空引用(Visual Basic 中为 Nothing)将使用 DefaultBinder。 |
callConvention | System-Reflection-CallingConventions | 该对象,用于指定要使用的一套规则,这些规则涉及参数的顺序和布局、传递返回值的方式、用于参数的寄存器和清理堆栈的方式。 |
types | System-Type[] | Type 对象数组,表示构造函数要获取的参数的个数、顺序和类型。- 或 -获取不使用参数的构造函数的 Type 类型的空数组(即 Type[] types = new Type[0])。 |
modifiers | System-Reflection-ParameterModifier[] | ParameterModifier 对象数组,表示与 types 数组中的相应元素关联的特性。默认的联编程序不处理此参数。 |
返回值 | System.Reflection.ConstructorInfo | 表示符合指定要求的构造函数的 ConstructorInfo 对象(如果找到的话);否则为 null。 |
提示和注释
虽然默认联编程序不处理 ParameterModifier(modifiers 参数),但您可以使用抽象 System.Reflection.Binder 类编写确实处理 modifiers 的自定义联编程序。 ParameterModifier 仅当通过 COM 互操作进行调用时才使用,而且仅处理通过引用传递的参数。
如果不存在完全匹配项,binder 将尝试强制 types 数组中指定的参数类型以便选择一个匹配项。 如果 binder 无法选择匹配项,则返回 null。
下列 BindingFlags 筛选标志可用于定义要包含在搜索中的构造函数:
为了获取返回值,必须指定 BindingFlags.Instance 或 BindingFlags.Static。
指定 BindingFlags.Public 可在搜索中包含公共构造函数。
指定 BindingFlags.NonPublic 可在搜索中包含非公共构造函数(即私有构造函数、内部构造函数和受保护的构造函数)。
有关更多信息,请参见 System.Reflection.BindingFlags。
此方法实现 GetConstructor。
System.Type.GetConstructorImpl 方法例子
异常
异常 | 异常描述 |
---|---|
ArgumentNullException |
|
ArgumentException |
|
NotSupportedException | 当前类型是 TypeBuilder 或 GenericTypeParameterBuilder。 |
版本信息
.NET Framework 受以下版本支持:4、3.5、3.0、2.0、1.1、1.0 .NET Framework Client Profile 受以下版本支持:4、3.5 SP1
适用平台
Windows 7, Windows Vista SP1 或更高版本, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008(不支持服务器核心), Windows Server 2008 R2(支持 SP1 或更高版本的服务器核心), Windows Server 2003 SP2 .NET Framework 并不是对每个平台的所有版本都提供支持。有关支持的版本的列表,请参见.NET Framework 系统要求。