FieldAttributes Перечисление

Определение

Задает флаги, описывающие атрибуты поля.Specifies flags that describe the attributes of a field.

Это перечисление имеет атрибут FlagsAttribute, который разрешает побитовое сочетание значений его элементов.

public enum class FieldAttributes
public enum FieldAttributes
[System.Flags]
public enum FieldAttributes
[System.Flags]
[System.Serializable]
public enum FieldAttributes
[System.Flags]
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public enum FieldAttributes
type FieldAttributes = 
[<System.Flags>]
type FieldAttributes = 
[<System.Flags>]
[<System.Serializable>]
type FieldAttributes = 
[<System.Flags>]
[<System.Serializable>]
[<System.Runtime.InteropServices.ComVisible(true)>]
type FieldAttributes = 
Public Enum FieldAttributes
Наследование
FieldAttributes
Атрибуты

Поля

Assembly 3

Определяет, что поле доступно во всей сборке.Specifies that the field is accessible throughout the assembly.

FamANDAssem 2

Определяет, что поле доступно только для подтипов в данной сборке.Specifies that the field is accessible only by subtypes in this assembly.

Family 4

Определяет, что поле доступно только для типа и подтипов.Specifies that the field is accessible only by type and subtypes.

FamORAssem 5

Определяет, что поле доступно для подтипов, находящихся где угодно, а также во всей сборке.Specifies that the field is accessible by subtypes anywhere, as well as throughout this assembly.

FieldAccessMask 7

Определяет уровень доступа для заданного поля.Specifies the access level of a given field.

HasDefault 32768

Определяет, что для поля задано значение по умолчанию.Specifies that the field has a default value.

HasFieldMarshal 4096

Определяет, что для поля заданы сведения о маршалинге.Specifies that the field has marshaling information.

HasFieldRVA 256

Определяет, что для поля задан RVA (Relative Virtual Address, относительный виртуальный адрес).Specifies that the field has a relative virtual address (RVA). RVA определяет местонахождение текста сообщения метода в текущем образе — адрес относительно начала файла образа, в котором оно находится.The RVA is the location of the method body in the current image, as an address relative to the start of the image file in which it is located.

InitOnly 32

Указывает, что поле инициализируется и задается только в теле конструктора.Specifies that the field is initialized only, and can be set only in the body of a constructor.

Literal 64

Определяет, что значение поля является константой (статической или с ранним связыванием), определяемой во время компиляции.Specifies that the field's value is a compile-time (static or early bound) constant. Любая попытка задать создает FieldAccessException.Any attempt to set it throws a FieldAccessException.

NotSerialized 128

Определяет, что если тип является удаленным, поле не должно быть сериализовано.Specifies that the field does not have to be serialized when the type is remoted.

PinvokeImpl 8192

Зарезервировано для будущего использования.Reserved for future use.

Private 1

Определяет, что поле доступно только для родительского типа.Specifies that the field is accessible only by the parent type.

PrivateScope 0

Определяет, что на поле нельзя ссылаться.Specifies that the field cannot be referenced.

Public 6

Определяет, что поле доступно любому члену, для которого эта ограниченная область действия является видимой.Specifies that the field is accessible by any member for whom this scope is visible.

ReservedMask 38144

Зарезервировано.Reserved.

RTSpecialName 1024

Определяет, что общеязыковая среда выполнения (внутренние API метаданных) должна проверить кодировку имени.Specifies that the common language runtime (metadata internal APIs) should check the name encoding.

SpecialName 512

Определяет специальный метод с именем, которое описывает, насколько этот метод является специальным.Specifies a special method, with the name describing how the method is special.

Static 16

Определяет, что поле представляет указанный тип или является полем для экземпляра.Specifies that the field represents the defined type, or else it is per-instance.

Примеры

В этом примере создаются три поля и FieldAttributes отображаются значения.In this example, three fields are built and the FieldAttributes values are displayed. FieldAttributesЗначение может содержать более одного атрибута, например Public и Literal , как показано в третьем поле.A FieldAttributes value can contain more than one attribute, for example, both Public and Literal, as shown in the third field.

using namespace System;
using namespace System::Reflection;
using namespace System::Security::Permissions;

public ref class Demo
{
private:
    // Make three fields:
    // The first field is private.
    String^ m_field;

    // The second field is public.
public:
    String^ Field;

    // The third field is public and literal. 
    literal String^ FieldC = "String C";

    Demo() { m_field = "String A"; Field = "String B"; }
};

static void DisplayField(Object^ obj, FieldInfo^ f)
{ 
    // Display the field name, value, and attributes.
    //
    Console::WriteLine("{0} = \"{1}\"; attributes: {2}", 
        f->Name, f->GetValue(obj), f->Attributes);
};

void main()
{
    Console::WriteLine ("\nReflection.FieldAttributes");
    Demo^ d = gcnew Demo();

    // Get a Type object for Demo, and a FieldInfo for each of
    // the three fields. Use the FieldInfo to display field
    // name, value for the Demo object in d, and attributes.
    //
    Type^ myType = Demo::typeid;

    FieldInfo^ fiPrivate = myType->GetField("m_field",
        BindingFlags::NonPublic | BindingFlags::Instance);
    DisplayField(d, fiPrivate);

    FieldInfo^ fiPublic = myType->GetField("Field",
        BindingFlags::Public | BindingFlags::Instance);
    DisplayField(d, fiPublic);

    FieldInfo^ fiConstant = myType->GetField("FieldC",
        BindingFlags::Public | BindingFlags::Static);
    DisplayField(d, fiConstant);
}

/* This code example produces the following output:

Reflection.FieldAttributes
m_field = "String A"; attributes: Private
Field = "String B"; attributes: Public
FieldC = "String C"; attributes: Public, Static, Literal, HasDefault
 */
using System;
using System.Reflection;

public class Demo
{
    // Make three fields:
    // The first field is private.
    private string m_field = "String A";

    // The second field is public.
    public string Field = "String B";

    // The third field is public const (hence also literal and static),
    // with a default value.
    public const string FieldC = "String C";
}

public class Myfieldattributes
{
    public static void Main()
    {
        Console.WriteLine ("\nReflection.FieldAttributes");
        Demo d = new Demo();

        // Get a Type object for Demo, and a FieldInfo for each of
        // the three fields. Use the FieldInfo to display field
        // name, value for the Demo object in d, and attributes.
        //
        Type myType = typeof(Demo);
        FieldInfo fiPrivate = myType.GetField("m_field",
            BindingFlags.NonPublic | BindingFlags.Instance);
        DisplayField(d, fiPrivate);

        FieldInfo fiPublic = myType.GetField("Field",
            BindingFlags.Public | BindingFlags.Instance);
        DisplayField(d, fiPublic);

        FieldInfo fiConstant = myType.GetField("FieldC",
            BindingFlags.Public | BindingFlags.Static);
        DisplayField(d, fiConstant);
    }

    static void DisplayField(Object obj, FieldInfo f)
    {
        // Display the field name, value, and attributes.
        //
        Console.WriteLine("{0} = \"{1}\"; attributes: {2}",
            f.Name, f.GetValue(obj), f.Attributes);
    }
}

/* This code example produces the following output:

Reflection.FieldAttributes
m_field = "String A"; attributes: Private
Field = "String B"; attributes: Public
FieldC = "String C"; attributes: Public, Static, Literal, HasDefault
 */
Imports System.Reflection

Public Class Demo
    ' Declare three fields.
    ' The first field is private.
    Private m_field As String = "String A"

    'The second field is public.
    Public Field As String = "String B"

    ' The third field is public and const, hence also static
    ' and literal with a default value.
    Public Const FieldC As String = "String C"

End Class

Module Module1
    Sub Main()
        ' Create an instance of the Demo class.
        Dim d As New Demo()

        Console.WriteLine(vbCrLf & "Reflection.FieldAttributes")

        ' Get a Type object for Demo, and a FieldInfo for each of
        ' the three fields. Use the FieldInfo to display field
        ' name, value for the Demo object in d, and attributes.
        '
        Dim myType As Type = GetType(Demo)

        Dim fiPrivate As FieldInfo = myType.GetField("m_field", _
            BindingFlags.NonPublic Or BindingFlags.Instance)
        DisplayField(d, fiPrivate)

        Dim fiPublic As FieldInfo = myType.GetField("Field", _
            BindingFlags.Public Or BindingFlags.Instance)
        DisplayField(d, fiPublic)

        Dim fiConstant As FieldInfo = myType.GetField("FieldC", _
            BindingFlags.Public Or BindingFlags.Static)
        DisplayField(d, fiConstant)
    End Sub

    Sub DisplayField(ByVal obj As Object, ByVal f As FieldInfo)

        ' Display the field name, value, and attributes.
        '
        Console.WriteLine("{0} = ""{1}""; attributes: {2}", _
            f.Name, f.GetValue(obj), f.Attributes)
    End Sub

End Module

' This code example produces the following output:
'
'm_field = "String A"; attributes: Private
'Field = "String B"; attributes: Public
'FieldC = "String C"; attributes: Public, Static, Literal, HasDefault

Комментарии

FieldAttributes использует значение из FieldAccessMask , чтобы маскировать только части значения атрибута, относящиеся к доступу.FieldAttributes uses the value from FieldAccessMask to mask off only the parts of the attribute value that pertain to the accessibility. Например, следующий код определяет, имеет ли Attributes общедоступный бит открытый набор.For example, the following code determines if Attributes has the public bit set.

FieldInfo^ fi = obj->GetType()->GetField("field1");

if ((fi->Attributes & FieldAttributes::FieldAccessMask) ==
    FieldAttributes::Public)
{
    Console::WriteLine("{0:s} is public. Value: {1:d}", fi->Name, fi->GetValue(obj));
}
FieldInfo fi = obj.GetType().GetField("field1");

if ((fi.Attributes & FieldAttributes.FieldAccessMask) ==
    FieldAttributes.Public)
{
    Console.WriteLine("{0:s} is public. Value: {1:d}", fi.Name, fi.GetValue(obj));
}
Dim fi As FieldInfo = obj.GetType().GetField("field1")

If (fi.Attributes And FieldAttributes.FieldAccessMask) = _
    FieldAttributes.Public Then
    Console.WriteLine("{0:s} is public. Value: {1:d}", fi.Name, fi.GetValue(obj))
End If

Чтобы получить FieldAttributes , сначала необходимо получить класс Type .To get the FieldAttributes, first get the class Type. В Type получите FieldInfo .From the Type, get the FieldInfo. В FieldInfo получите Attributes .From the FieldInfo, get the Attributes.

Перечислимое значение — это число, представляющее побитовое или для атрибутов, реализованных в поле.The enumerated value is a number representing the bitwise OR of the attributes implemented on the field.

Применяется к