ParameterInfo.GetCustomAttributes 方法
定義
重要
部分資訊涉及發行前產品,在發行之前可能會有大幅修改。 Microsoft 對此處提供的資訊,不做任何明確或隱含的瑕疵擔保。
取得套用至這個參數的自訂屬性。
多載
GetCustomAttributes(Type, Boolean) |
取得套用至此參數之指定型別及其衍生型別的自訂屬性。 |
GetCustomAttributes(Boolean) |
取得在這個參數上所定義的所有自訂屬性。 |
GetCustomAttributes(Type, Boolean)
取得套用至此參數之指定型別及其衍生型別的自訂屬性。
public:
virtual cli::array <System::Object ^> ^ GetCustomAttributes(Type ^ attributeType, bool inherit);
public virtual object[] GetCustomAttributes (Type attributeType, bool inherit);
abstract member GetCustomAttributes : Type * bool -> obj[]
override this.GetCustomAttributes : Type * bool -> obj[]
Public Overridable Function GetCustomAttributes (attributeType As Type, inherit As Boolean) As Object()
參數
- attributeType
- Type
依型別識別的自訂屬性。
- inherit
- Boolean
這個類型的物件會忽略這個引數。
傳回
包含指定型別及其衍生型別之自訂屬性的陣列。
實作
例外狀況
類型必須是基礎執行階段系統所提供的類型。
attributeType
為 null
。
無法載入自訂屬性型別。
備註
這個方法會 inherit
忽略 參數。 若要搜尋繼承鏈結中的參數屬性,請使用 方法的適當 Attribute.GetCustomAttributes 多載。
適用於
GetCustomAttributes(Boolean)
取得在這個參數上所定義的所有自訂屬性。
public:
virtual cli::array <System::Object ^> ^ GetCustomAttributes(bool inherit);
public virtual object[] GetCustomAttributes (bool inherit);
abstract member GetCustomAttributes : bool -> obj[]
override this.GetCustomAttributes : bool -> obj[]
Public Overridable Function GetCustomAttributes (inherit As Boolean) As Object()
參數
- inherit
- Boolean
這個類型的物件會忽略這個引數。
傳回
包含套用至此參數之所有自訂屬性的陣列。
實作
例外狀況
無法載入自訂屬性型別。
範例
下列範例示範如何在運行時間擷取已套用至方法參數的自定義屬性。 此範例會定義名為 的 MyAttribute
自定義屬性,可套用至參數。 然後,此範例會使用名為 的方法定義名為 MyClass
MyMethod
的類別,並套用 MyAttribute
至 方法的參數。
執行範例時,它會使用 GetCustomAttributes(Boolean) 方法來擷取已套用至 中 MyClass
所有方法之所有參數的自定義屬性,並在控制台上顯示它們。
using namespace System;
using namespace System::Reflection;
// Define a custom attribute with one named parameter.
[AttributeUsage(AttributeTargets::Parameter)]
public ref class MyAttribute: public Attribute
{
private:
String^ myName;
public:
MyAttribute( String^ name )
{
myName = name;
}
property String^ Name
{
String^ get()
{
return myName;
}
}
};
// Define a class which has a custom attribute associated with one of the
// parameters of a method.
public ref class MyClass1
{
public:
void MyMethod(
[MyAttribute("This is an example parameter attribute")]
int i ) {}
};
void main()
{
// Get the type of the class 'MyClass1'.
Type^ myType = MyClass1::typeid;
// Get the members associated with the class 'MyClass1'.
array<MethodInfo^>^myMethods = myType->GetMethods();
// Display the attributes for each of the parameters of each method of the class 'MyClass1'.
for ( int i = 0; i < myMethods->Length; i++ )
{
// Get the parameters for the method.
array<ParameterInfo^>^myParameters = myMethods[ i ]->GetParameters();
if ( myParameters->Length > 0 )
{
Console::WriteLine( "\nThe parameters for the method \"{0}\" that have custom attributes are:", myMethods[ i ] );
for ( int j = 0; j < myParameters->Length; j++ )
{
// Get the attributes of type 'MyAttribute' for each parameter.
array<Object^>^myAttributes = myParameters[ j ]->GetCustomAttributes( MyAttribute::typeid, false );
if ( myAttributes->Length > 0 )
{
Console::WriteLine( "Parameter {0}, name = {1}, type = {2} has attributes:",
myParameters[ j ]->Position,
myParameters[ j ]->Name,
myParameters[ j ]->ParameterType );
for ( int k = 0; k < myAttributes->Length; k++ )
{
Console::WriteLine( "\t{0}", myAttributes[ k ] );
}
}
}
}
}
}
/* This code example produces the following output:
The parameters for the method Void MyMethod(Int32) that have custom attributes are :
Parameter 0, name = i, type = System.Int32 has attributes:
MyAttribute
The parameters for the method Boolean Equals(System.Object) that have custom attributes are :
*/
using System;
using System.Reflection;
// Define a custom attribute with one named parameter.
[AttributeUsage(AttributeTargets.Parameter)]
public class MyAttribute : Attribute
{
private string myName;
public MyAttribute(string name)
{
myName = name;
}
public string Name
{
get
{
return myName;
}
}
}
// Define a class which has a custom attribute associated with one of the
// parameters of a method.
public class MyClass1
{
public void MyMethod(
[MyAttribute("This is an example parameter attribute")]
int i)
{
return;
}
}
public class MemberInfo_GetCustomAttributes
{
public static void Main()
{
// Get the type of the class 'MyClass1'.
Type myType = typeof(MyClass1);
// Get the members associated with the class 'MyClass1'.
MethodInfo[] myMethods = myType.GetMethods();
// Display the attributes for each of the parameters of each method of the class 'MyClass1'.
for(int i = 0; i < myMethods.Length; i++)
{
// Get the parameters for the method.
ParameterInfo[] myParameters = myMethods[i].GetParameters();
if (myParameters.Length > 0)
{
Console.WriteLine("\nThe parameters for the method {0} that have custom attributes are :", myMethods[i]);
for(int j = 0; j < myParameters.Length; j++)
{
// Get the attributes of type 'MyAttribute' for each parameter.
Object[] myAttributes = myParameters[j].GetCustomAttributes(typeof(MyAttribute), false);
if (myAttributes.Length > 0)
{
Console.WriteLine("Parameter {0}, name = {1}, type = {2} has attributes: ",
myParameters[j].Position, myParameters[j].Name, myParameters[j].ParameterType);
for(int k = 0; k < myAttributes.Length; k++)
{
Console.WriteLine("\t{0}", myAttributes[k]);
}
}
}
}
}
}
}
/* This code example produces the following output:
The parameters for the method Void MyMethod(Int32) that have custom attributes are :
Parameter 0, name = i, type = System.Int32 has attributes:
MyAttribute
The parameters for the method Boolean Equals(System.Object) that have custom attributes are :
*/
Imports System.Reflection
' Define a custom attribute with one named parameter.
<AttributeUsage(AttributeTargets.Parameter)> Public Class MyAttribute
Inherits Attribute
Private myName As String
Public Sub New(ByVal name As String)
myName = name
End Sub
Public ReadOnly Property Name() As String
Get
Return myName
End Get
End Property
End Class
' Define a class which has a custom attribute associated with one of
' the parameters of a method.
Public Class MyClass1
Public Sub MyMethod( _
<MyAttribute("This is an example parameter attribute")> _
ByVal i As Integer _
)
Return
End Sub
End Class
Public Class MemberInfo_GetCustomAttributes
Public Shared Sub Main()
' Get the type of the class 'MyClass1'.
Dim myType As Type = GetType(MyClass1)
' Get the members associated with the class 'MyClass1'.
Dim myMethods As MethodInfo() = myType.GetMethods()
' Display the attributes for each of the parameters of each method of the class 'MyClass1'.
For i As Integer = 0 To myMethods.Length - 1
' Get the parameters for the method.
Dim myParameters As ParameterInfo() = myMethods(i).GetParameters()
If myParameters.Length > 0 Then
Console.WriteLine(vbCrLf & "The parameters for the method {0} that have custom attributes are : ", myMethods(i))
For j As Integer = 0 To myParameters.Length - 1
' Get the attributes of type 'MyAttribute' for each parameter.
Dim myAttributes As Object() = myParameters(j).GetCustomAttributes(GetType(MyAttribute), False)
If myAttributes.Length > 0 Then
Console.WriteLine("Parameter {0}, name = {1}, type = {2} has attributes: ", _
myParameters(j).Position, myParameters(j).Name, myParameters(j).ParameterType)
For k As Integer = 0 To myAttributes.Length - 1
Console.WriteLine(vbTab & "{0}", myAttributes(k))
Next k
End If
Next j
End If
Next i
End Sub
End Class
' This code example produces the following output:
'
'The parameters for the method Void MyMethod(Int32) that have custom attributes are :
'Parameter 0, name = i, type = System.Int32 has attributes:
' MyAttribute
'
'The parameters for the method Boolean Equals(System.Object) that have custom attributes are :
備註
這個方法會 inherit
忽略 參數。 若要搜尋繼承鏈結中的參數屬性,請使用 方法的適當 Attribute.GetCustomAttributes 多載。