İngilizce dilinde oku

Aracılığıyla paylaş


Attribute Sınıf

Tanım

Özel öznitelikler için temel sınıfı temsil eder.

[System.AttributeUsage(System.AttributeTargets.All, AllowMultiple=false, Inherited=true)]
public abstract class Attribute
[System.AttributeUsage(System.AttributeTargets.All, AllowMultiple=false, Inherited=true)]
[System.Runtime.InteropServices.ClassInterface(System.Runtime.InteropServices.ClassInterfaceType.None)]
[System.Serializable]
public abstract class Attribute : System.Runtime.InteropServices._Attribute
[System.AttributeUsage(System.AttributeTargets.All, AllowMultiple=false, Inherited=true)]
[System.Runtime.InteropServices.ClassInterface(System.Runtime.InteropServices.ClassInterfaceType.None)]
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public abstract class Attribute : System.Runtime.InteropServices._Attribute
Devralma
Attribute
Türetilmiş
Öznitelikler
Uygulamalar

Örnekler

Aşağıdaki kod örneğinde Attributekullanımı gösterilmektedir.

using System;
using System.Reflection;

// An enumeration of animals. Start at 1 (0 = uninitialized).
public enum Animal {
    // Pets.
    Dog = 1,
    Cat,
    Bird,
}

// A custom attribute to allow a target to have a pet.
public class AnimalTypeAttribute : Attribute {
    // The constructor is called when the attribute is set.
    public AnimalTypeAttribute(Animal pet) {
        thePet = pet;
    }

    // Keep a variable internally ...
    protected Animal thePet;

    // .. and show a copy to the outside world.
    public Animal Pet {
        get { return thePet; }
        set { thePet = value; }
    }
}

// A test class where each method has its own pet.
class AnimalTypeTestClass {
    [AnimalType(Animal.Dog)]
    public void DogMethod() {}

    [AnimalType(Animal.Cat)]
    public void CatMethod() {}

    [AnimalType(Animal.Bird)]
    public void BirdMethod() {}
}

class DemoClass {
    static void Main(string[] args) {
        AnimalTypeTestClass testClass = new AnimalTypeTestClass();
        Type type = testClass.GetType();
        // Iterate through all the methods of the class.
        foreach(MethodInfo mInfo in type.GetMethods()) {
            // Iterate through all the Attributes for each method.
            foreach (Attribute attr in
                Attribute.GetCustomAttributes(mInfo)) {
                // Check for the AnimalType attribute.
                if (attr.GetType() == typeof(AnimalTypeAttribute))
                    Console.WriteLine(
                        "Method {0} has a pet {1} attribute.",
                        mInfo.Name, ((AnimalTypeAttribute)attr).Pet);
            }
        }
    }
}
/*
 * Output:
 * Method DogMethod has a pet Dog attribute.
 * Method CatMethod has a pet Cat attribute.
 * Method BirdMethod has a pet Bird attribute.
 */

Açıklamalar

Attribute sınıfı, önceden tanımlanmış sistem bilgilerini veya kullanıcı tanımlı özel bilgileri bir hedef öğeyle ilişkilendirir. Hedef öğe bir derleme, sınıf, oluşturucu, temsilci, numaralandırma, olay, alan, arabirim, yöntem, taşınabilir yürütülebilir dosya modülü, parametre, özellik, dönüş değeri, yapısı veya başka bir öznitelik olabilir.

Bir öznitelik tarafından sağlanan bilgiler meta veri olarak da bilinir. Meta veriler, uygulamanızın verileri nasıl işlediğini denetlemek için uygulamanız tarafından çalışma zamanında incelenebilir veya uygulamanızın nasıl işlendiğini veya bakımının nasıl yapıldığını denetlemek için dış araçlar tarafından çalışma zamanından önce incelenebilir. Örneğin, .NET çalışma zamanı davranışını denetlemek için öznitelik türlerini önceden tanımlanmış ve kullanır ve bazı programlama dilleri ise .NET ortak tür sistemi tarafından doğrudan desteklenmeyen dil özelliklerini temsil etmek için öznitelik türlerini kullanır.

Tüm öznitelik türleri doğrudan veya dolaylı olarak Attribute sınıfından türetilir. Öznitelikler herhangi bir hedef öğeye uygulanabilir; aynı hedef öğeye birden çok öznitelik uygulanabilir; ve öznitelikleri, hedef öğeden türetilen bir öğe tarafından devralınabilir. özniteliğinin uygulandığı hedef öğeyi belirtmek için AttributeTargets sınıfını kullanın.

Attribute sınıfı, özel öznitelikleri almak ve test etmek için kullanışlı yöntemler sağlar. Öznitelikleri kullanma hakkında daha fazla bilgi için bkz. Öznitelikleri Uygulama ve Öznitelikleri.

Oluşturucular

Attribute()

Attribute sınıfının yeni bir örneğini başlatır.

Özellikler

TypeId

Türetilmiş bir sınıfta uygulandığında, bu Attributeiçin benzersiz bir tanımlayıcı alır.

Yöntemler

Equals(Object)

Bu örneğin belirtilen bir nesneye eşit olup olmadığını gösteren bir değer döndürür.

GetCustomAttribute(Assembly, Type, Boolean)

Bir derlemeye uygulanan özel özniteliği alır. Parametreler derlemeyi, aranacak özel özniteliğin türünü ve yoksayılan arama seçeneğini belirtir.

GetCustomAttribute(Assembly, Type)

Belirtilen derlemeye uygulanan özel bir özniteliği alır. Parametreler, aranacak özel özniteliğin derlemesini ve türünü belirtir.

GetCustomAttribute(MemberInfo, Type, Boolean)

Bir türün üyesine uygulanan özel özniteliği alır. Parametreler üyeyi, aranacak özel özniteliğin türünü ve üyenin atalarının aranıp aranmayacağını belirtir.

GetCustomAttribute(MemberInfo, Type)

Bir türün üyesine uygulanan özel özniteliği alır. Parametreler, üyeyi ve aranacak özel özniteliğin türünü belirtir.

GetCustomAttribute(Module, Type, Boolean)

Modüle uygulanan özel bir özniteliği alır. Parametreler modülü, aranacak özel özniteliğin türünü ve yoksayılan arama seçeneğini belirtir.

GetCustomAttribute(Module, Type)

Modüle uygulanan özel bir özniteliği alır. Parametreler modülü ve aranacak özel özniteliğin türünü belirtir.

GetCustomAttribute(ParameterInfo, Type, Boolean)

Yöntem parametresine uygulanan özel bir özniteliği alır. Parametreler yöntem parametresini, aranacak özel özniteliğin türünü ve yöntem parametresinin alt öğesinin aranıp aranmayacağını belirtir.

GetCustomAttribute(ParameterInfo, Type)

Yöntem parametresine uygulanan özel bir özniteliği alır. Parametreler yöntem parametresini ve aranacak özel özniteliğin türünü belirtir.

GetCustomAttributes(Assembly, Boolean)

Bir derlemeye uygulanan özel özniteliklerin dizisini alır. Parametreler derlemeyi ve yoksayılan arama seçeneğini belirtir.

GetCustomAttributes(Assembly, Type, Boolean)

Bir derlemeye uygulanan özel özniteliklerin dizisini alır. Parametreler derlemeyi, aranacak özel özniteliğin türünü ve yoksayılan arama seçeneğini belirtir.

GetCustomAttributes(Assembly, Type)

Bir derlemeye uygulanan özel özniteliklerin dizisini alır. Parametreler derlemeyi ve aranacak özel özniteliğin türünü belirtir.

GetCustomAttributes(Assembly)

Bir derlemeye uygulanan özel özniteliklerin dizisini alır. Parametresi derlemeyi belirtir.

GetCustomAttributes(MemberInfo, Boolean)

Bir türün üyesine uygulanan özel özniteliklerin dizisini alır. Parametreler üyeyi, aranacak özel özniteliğin türünü ve üyenin atalarının aranıp aranmayacağını belirtir.

GetCustomAttributes(MemberInfo, Type, Boolean)

Bir türün üyesine uygulanan özel özniteliklerin dizisini alır. Parametreler üyeyi, aranacak özel özniteliğin türünü ve üyenin atalarının aranıp aranmayacağını belirtir.

GetCustomAttributes(MemberInfo, Type)

Bir türün üyesine uygulanan özel özniteliklerin dizisini alır. Parametreler, üyeyi ve aranacak özel özniteliğin türünü belirtir.

GetCustomAttributes(MemberInfo)

Bir türün üyesine uygulanan özel özniteliklerin dizisini alır. Bir parametre üyeyi belirtir.

GetCustomAttributes(Module, Boolean)

Modüle uygulanan özel özniteliklerin dizisini alır. Parametreler modülü ve yoksayılan arama seçeneğini belirtir.

GetCustomAttributes(Module, Type, Boolean)

Modüle uygulanan özel özniteliklerin dizisini alır. Parametreler modülü, aranacak özel özniteliğin türünü ve yoksayılan arama seçeneğini belirtir.

GetCustomAttributes(Module, Type)

Modüle uygulanan özel özniteliklerin dizisini alır. Parametreler modülü ve aranacak özel özniteliğin türünü belirtir.

GetCustomAttributes(Module)

Modüle uygulanan özel özniteliklerin dizisini alır. Parametresi modülü belirtir.

GetCustomAttributes(ParameterInfo, Boolean)

Bir yöntem parametresine uygulanan özel özniteliklerin dizisini alır. Parametreler yöntem parametresini ve yöntem parametresinin atalarının aranıp aranmayacağını belirtir.

GetCustomAttributes(ParameterInfo, Type, Boolean)

Bir yöntem parametresine uygulanan özel özniteliklerin dizisini alır. Parametreler yöntem parametresini, aranacak özel özniteliğin türünü ve yöntem parametresinin alt öğesinin aranıp aranmayacağını belirtir.

GetCustomAttributes(ParameterInfo, Type)

Bir yöntem parametresine uygulanan özel özniteliklerin dizisini alır. Parametreler yöntem parametresini ve aranacak özel özniteliğin türünü belirtir.

GetCustomAttributes(ParameterInfo)

Bir yöntem parametresine uygulanan özel özniteliklerin dizisini alır. parametresi yöntem parametresini belirtir.

GetHashCode()

Bu örneğin karma kodunu döndürür.

GetType()

Geçerli örneğin Type alır.

(Devralındığı yer: Object)
IsDefaultAttribute()

Türetilmiş bir sınıfta geçersiz kılındığında, bu örneğin değerinin türetilmiş sınıf için varsayılan değer olup olmadığını gösterir.

IsDefined(Assembly, Type, Boolean)

Herhangi bir özel özniteliğin bir derlemeye uygulanıp uygulanmadığını belirler. Parametreler derlemeyi, aranacak özel özniteliğin türünü ve yoksayılan arama seçeneğini belirtir.

IsDefined(Assembly, Type)

Herhangi bir özel özniteliğin bir derlemeye uygulanıp uygulanmadığını belirler. Parametreler derlemeyi ve aranacak özel özniteliğin türünü belirtir.

IsDefined(MemberInfo, Type, Boolean)

Herhangi bir özel özniteliğin bir türün üyesine uygulanıp uygulanmadığını belirler. Parametreler üyeyi, aranacak özel özniteliğin türünü ve üyenin atalarının aranıp aranmayacağını belirtir.

IsDefined(MemberInfo, Type)

Herhangi bir özel özniteliğin bir türün üyesine uygulanıp uygulanmadığını belirler. Parametreler, üyeyi ve aranacak özel özniteliğin türünü belirtir.

IsDefined(Module, Type, Boolean)

Herhangi bir özel özniteliğin bir modüle uygulanıp uygulanmadığını belirler. Parametreler modülü, aranacak özel özniteliğin türünü ve yoksayılan arama seçeneğini belirtir.

IsDefined(Module, Type)

Belirli bir türe ait özel özniteliklerin modüle uygulanıp uygulanmadığını belirler. Parametreler modülü ve aranacak özel özniteliğin türünü belirtir.

IsDefined(ParameterInfo, Type, Boolean)

Herhangi bir özel özniteliğin bir yöntem parametresine uygulanıp uygulanmadığını belirler. Parametreler yöntem parametresini, aranacak özel özniteliğin türünü ve yöntem parametresinin alt öğesinin aranıp aranmayacağını belirtir.

IsDefined(ParameterInfo, Type)

Herhangi bir özel özniteliğin bir yöntem parametresine uygulanıp uygulanmadığını belirler. Parametreler yöntem parametresini ve aranacak özel özniteliğin türünü belirtir.

Match(Object)

Türetilmiş bir sınıfta geçersiz kılındığında, bu örneğin belirtilen bir nesneye eşit olup olmadığını gösteren bir değer döndürür.

MemberwiseClone()

Geçerli Objectbasit bir kopyasını oluşturur.

(Devralındığı yer: Object)
ToString()

Geçerli nesneyi temsil eden bir dize döndürür.

(Devralındığı yer: Object)

Belirtik Arabirim Kullanımları

_Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr)

Bir ad kümesini ilgili dağıtım tanımlayıcıları kümesiyle eşler.

_Attribute.GetTypeInfo(UInt32, UInt32, IntPtr)

Bir arabirimin tür bilgilerini almak için kullanılabilecek bir nesnenin tür bilgilerini alır.

_Attribute.GetTypeInfoCount(UInt32)

Bir nesnenin sağladığı tür bilgisi arabirimlerinin sayısını alır (0 veya 1).

_Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

Bir nesne tarafından kullanıma sunulan özelliklere ve yöntemlere erişim sağlar.

Şunlara uygulanır

Ürün Sürümler
.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
.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.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

İş Parçacığı Güvenliği

Bu tür iş parçacığı güvenlidir.

Ayrıca bkz.

  • öznitelikleri uygulama
  • Öznitelikler Kullanarak Meta Verileri Genişletmeyi