CodeClass2.AddDelegate 方法
在指定类中创建一个新委托。
命名空间: EnvDTE80
程序集: EnvDTE80(在 EnvDTE80.dll 中)
语法
声明
Function AddDelegate ( _
Name As String, _
Type As Object, _
Position As Object, _
Access As vsCMAccess _
) As CodeDelegate
CodeDelegate AddDelegate(
string Name,
Object Type,
Object Position,
vsCMAccess Access
)
CodeDelegate^ AddDelegate(
String^ Name,
Object^ Type,
Object^ Position,
vsCMAccess Access
)
abstract AddDelegate :
Name:string *
Type:Object *
Position:Object *
Access:vsCMAccess -> CodeDelegate
function AddDelegate(
Name : String,
Type : Object,
Position : Object,
Access : vsCMAccess
) : CodeDelegate
参数
Name
类型:String必选。 要添加的委托的名称。
Type
类型:Object必选。 一个 vsCMTypeRef 常数,该常数指示函数返回的数据类型。 它可以是 CodeTypeRef 对象、vsCMTypeRef 常数或完全限定的类型名。
Position
类型:Object可选。 默认值 = 0。 将在其后添加新元素的代码元素。
如果该值为 Long 数据类型,则 Position 指示在哪个元素的后面添加新元素。
因为集合从 1 开始计数,所以传递 0 指示应将新元素放置在集合的开始处。 值为 -1 表示应将元素放在结尾处。
Access
类型:vsCMAccess可选。 一个指定访问类型的 vsCMAccess 常数。
返回值
类型:CodeDelegate
一个 CodeDelegate 对象。
备注
本机 Visual C++ 要求其完全限定类型名使用以冒号 (::) 分隔的格式。 所有其他语言都使用以句点分隔的格式。
参数正确与否由代码模型后面的语言决定。
备注
在进行某些类型的编辑之后,代码模型元素(如类、结构、函数、特性、委托等)的值可能是非确定性的,这意味着不能指望它们的值总是保持不变。有关更多信息,请参见 使用代码模型查找代码 (Visual Basic) 中的“代码模型元素的值可能会更改”一节。
示例
[C#]
public void CodeClass2AddDelegateExample(DTE2 dte2)
{
// Before running this example, open a code document from a project
// and place the insertion point inside a class definition.
try
{
// Retrieve the CodeClass at the insertion point.
TextSelection sel =
TextSelection)dte2.ActiveDocument.Selection;
CodeClass cls =
(CodeClass)sel.ActivePoint.get_CodeElement(
vsCMElement.vsCMElementClass);
object pos = -1; // Place class at end of members collection
// Add delegate.
CodeDelegate cdel = cls.AddDelegate("TestDelegate",
vsCMTypeRef.vsCMTypeRefBool,
pos, vsCMAccess.vsCMAccessPublic);
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
.NET Framework 安全性
- 对直接调用方的完全信任。此成员不能由部分信任的代码使用。有关详细信息,请参阅通过部分受信任的代码使用库。