ClassInterfaceAttribute 类
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
指示在完全生成某个接口后为要向 COM 公开的类生成的类接口类型。
public ref class ClassInterfaceAttribute sealed : Attribute
[System.AttributeUsage(System.AttributeTargets.Assembly | System.AttributeTargets.Class, Inherited=false)]
public sealed class ClassInterfaceAttribute : Attribute
[System.AttributeUsage(System.AttributeTargets.Assembly | System.AttributeTargets.Class, Inherited=false)]
[System.Runtime.InteropServices.ComVisible(true)]
public sealed class ClassInterfaceAttribute : Attribute
[<System.AttributeUsage(System.AttributeTargets.Assembly | System.AttributeTargets.Class, Inherited=false)>]
type ClassInterfaceAttribute = class
inherit Attribute
[<System.AttributeUsage(System.AttributeTargets.Assembly | System.AttributeTargets.Class, Inherited=false)>]
[<System.Runtime.InteropServices.ComVisible(true)>]
type ClassInterfaceAttribute = class
inherit Attribute
Public NotInheritable Class ClassInterfaceAttribute
Inherits Attribute
- 继承
- 属性
以下示例演示如何应用ClassInterfaceAttribute值 AutoDispatch为 生成IDispatch
接口MyClass
的 ClassInterfaceType 。
using namespace System::Runtime::InteropServices;
[ClassInterface(ClassInterfaceType::AutoDispatch)]
public ref class MyClass
{
public:
MyClass(){}
};
using System.Runtime.InteropServices;
[ClassInterface(ClassInterfaceType.AutoDispatch)]
public class MyClass
{
public MyClass() {}
}
Imports System.Runtime.InteropServices
<ClassInterface(ClassInterfaceType.AutoDispatch)> _
Public Class SampleClass
' Insert class members here.
End Class
可以将此属性应用于程序集或类。
此属性控制类型库导出程序 (Tlbexp.exe) 是否自动生成特性化类的类接口。 类接口携带与类本身相同的名称,但名称带有下划线前缀。 公开时,类接口包含托管类的所有 public
非 static
成员,包括从其基类继承的成员。 托管类无法访问类接口,并且无需访问,因为它们可以直接访问类成员。 Tlbexp.exe 为类接口生成唯一的接口标识符 (IID) 。
类接口可以是双接口,也可以是仅调度接口。 (可选)可以禁止生成类接口,改为提供自定义接口。 通过指定 System.Runtime.InteropServices.ClassInterfaceType 枚举成员来公开或禁止类接口。 应用于 ClassInterfaceAttribute 程序集时, 属性与程序集中的所有类相关,除非各个类使用自己的属性替代设置。
尽管类接口无需为每个类显式定义接口,但强烈建议不要在生产应用程序中使用它们。 双类接口允许客户端绑定到特定的接口布局,该布局可能会随着类的发展而更改。 例如,考虑向 COM 客户端公开类接口的托管类。 类的第一个版本包含 方法和 North
South
。 非托管客户端可以绑定到类接口,该接口提供 North
作为类接口中的第一个方法,将 方法 South
作为第二种方法提供。 现在考虑类的下一个版本,该类在 方法East
和 South
之间插入了一个新方法 North
。 尝试通过旧类接口绑定到新类的非托管客户端在打算调用 方法 East
时,最终会调用 方法 South
,因为接口中方法的位置已更改。 此外,对基类布局的任何更改也会影响所有派生类的类接口布局。 直接绑定到类的托管客户端不会出现相同的版本控制问题。 有关使用类接口的具体准则,请参阅 COM 可调用包装器。
Tlbimp.exe (类型库导入程序) 始终应用于导入的ClassInterfaceType.None类枚举成员,以指示现有 COM 类永远不会公开托管接口。
Class |
使用指定的 ClassInterfaceType 枚举成员初始化 ClassInterfaceAttribute 类的新实例。 |
Class |
使用指定的 ClassInterfaceType 枚举值初始化 ClassInterfaceAttribute 类的新实例。 |
Type |
在派生类中实现时,获取此 Attribute 的唯一标识符。 (继承自 Attribute) |
Value |
获取 ClassInterfaceType 值,该值描述应为该类生成的接口的类型。 |
Equals(Object) |
返回一个值,该值指示此实例是否与指定的对象相等。 (继承自 Attribute) |
Get |
返回此实例的哈希代码。 (继承自 Attribute) |
Get |
获取当前实例的 Type。 (继承自 Object) |
Is |
在派生类中重写时,指示此实例的值是否是派生类的默认值。 (继承自 Attribute) |
Match(Object) |
当在派生类中重写时,返回一个指示此实例是否等于指定对象的值。 (继承自 Attribute) |
Memberwise |
创建当前 Object 的浅表副本。 (继承自 Object) |
To |
返回表示当前对象的字符串。 (继承自 Object) |
_Attribute. |
将一组名称映射为对应的一组调度标识符。 (继承自 Attribute) |
_Attribute. |
检索对象的类型信息,然后可以使用该信息获取接口的类型信息。 (继承自 Attribute) |
_Attribute. |
检索对象提供的类型信息接口的数量(0 或 1)。 (继承自 Attribute) |
_Attribute. |
提供对某一对象公开的属性和方法的访问。 (继承自 Attribute) |
产品 | 版本 |
---|---|
.NET | Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10 |
.NET Framework | 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 |
.NET Standard | 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1 |
UWP | 10.0 |