Прочитать на английском

Поделиться через


Module.GetCustomAttributes Метод

Определение

Возвращает настраиваемые атрибуты.

Перегрузки

GetCustomAttributes(Boolean)

Возвращает все настраиваемые атрибуты.

GetCustomAttributes(Type, Boolean)

Возвращает настраиваемые атрибуты заданного типа.

GetCustomAttributes(Boolean)

Исходный код:
Module.cs
Исходный код:
Module.cs
Исходный код:
Module.cs

Возвращает все настраиваемые атрибуты.

public virtual object[] GetCustomAttributes (bool inherit);

Параметры

inherit
Boolean

Данный аргумент не учитывается для объектов этого типа.

Возвращаемое значение

Object[]

Массив типа Object, содержащий все настраиваемые атрибуты.

Реализации

Примеры

В следующем примере отображаются имена модулей, которые соответствуют заданным условиям поиска.

using System;
using System.Reflection;
//Define a module-level attribute.
[module: ReflectionModule_Examples.MySimpleAttribute("module-level")]
namespace ReflectionModule_Examples
{
    class MyMainClass
    {
        static void Main()
        {
            Module[] moduleArray;
            moduleArray = typeof(MyMainClass).Assembly.GetModules(false);
            // In a simple project with only one module, the module at index
            // 0 will be the module containing these classes.
            Module myModule = moduleArray[0];
            object[] attributes;
            attributes = myModule.GetCustomAttributes(true);
            foreach(Object o in attributes)
            {
                Console.WriteLine("Found this attribute on myModule: {0}.", o.ToString());
            }
        }
    }
    //A very simple custom attribute.
    [AttributeUsage(AttributeTargets.Class | AttributeTargets.Module)]
    public class MySimpleAttribute : Attribute
    {
        private string name;

        public MySimpleAttribute(string newName)
        {
            name = newName;
        }
    }
}

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

.NET 9 и другие версии
Продукт Версии
.NET 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 2.0, 2.1

GetCustomAttributes(Type, Boolean)

Исходный код:
Module.cs
Исходный код:
Module.cs
Исходный код:
Module.cs

Возвращает настраиваемые атрибуты заданного типа.

public virtual object[] GetCustomAttributes (Type attributeType, bool inherit);

Параметры

attributeType
Type

Тип возвращаемого атрибута.

inherit
Boolean

Данный аргумент не учитывается для объектов этого типа.

Возвращаемое значение

Object[]

Массив объектов типа Object, содержащий все пользовательские атрибуты заданного типа.

Реализации

Исключения

attributeType имеет значение null.

attributeType не является объектом Type, предоставляемым средой выполнения. Например, attributeType является объектом TypeBuilder.

Примеры

В следующем примере отображаются имена модулей указанного типа, соответствующие заданным условиям поиска.

using System;
using System.Reflection;
//Define a module-level attribute.
[module: ReflectionModule_Examples.MySimpleAttribute("module-level")]
namespace ReflectionModule_Examples
{
    class MyMainClass
    {
        static void Main()
        {
            Module[] moduleArray;
            moduleArray = typeof(MyMainClass).Assembly.GetModules(false);
            // In a simple project with only one module, the module at index
            // 0 will be the module containing these classes.
            Module myModule = moduleArray[0];
            object[] attributes;
            //Get only MySimpleAttribute attributes for this module.
            attributes = myModule.GetCustomAttributes(
                myModule.GetType("ReflectionModule_Examples.MySimpleAttribute", false, false),
                true);
            foreach(Object o in attributes)
            {
                Console.WriteLine("Found this attribute on myModule: {0}", o.ToString());
            }
        }
    }

    // Define a very simple custom attribute
    [AttributeUsage(AttributeTargets.Class | AttributeTargets.Module)]
    public class MySimpleAttribute : Attribute
    {
        private string name;

        public MySimpleAttribute(string newName)
        {
            name = newName;
        }
    }
}

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

.NET 9 и другие версии
Продукт Версии
.NET 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 2.0, 2.1