导读:本期聚焦于小伙伴创作的《C#怎么使用特性Attribute 自定义特性和内置特性怎么定义和获取使用》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《C#怎么使用特性Attribute 自定义特性和内置特性怎么定义和获取使用》有用,将其分享出去将是对创作者最好的鼓励。

C#中的特性Attribute是一种用于为程序元素(类、方法、属性等)添加元数据信息的特殊类,这些元数据可以在编译或运行时被读取,从而实现额外的功能逻辑。特性本质上继承自System.Attribute的类的实例,通过方括号[]标注在目标元素上方使用。

C#怎么使用特性Attribute 自定义特性和内置特性怎么定义和获取使用

C#内置特性的使用

C#已经提供了很多常用的内置特性,开发者可以直接使用这些特性来简化开发工作,下面介绍几个常见的内置特性用法。

Obsolete特性

Obsolete特性用于标记已经过时的程序元素,当其他代码调用该元素时,编译器会给出对应的警告或错误提示。

using System;

public class Demo
{
    // 标记方法已过时,使用时会提示警告,第二个参数为true时会直接报错
    [Obsolete("该方法已过时,请使用NewMethod代替", false)]
    public void OldMethod()
    {
        Console.WriteLine("这是旧方法");
    }

    public void NewMethod()
    {
        Console.WriteLine("这是新方法");
    }
}

Serializable特性

Serializable特性用于标记类可以被序列化,标注该特性后,类的实例可以通过序列化工具转换为字节流或字符串存储、传输。

using System;

// 标记该类支持序列化
[Serializable]
public class User
{
    public string Name { get; set; }
    public int Age { get; set; }
}

C#自定义特性的定义

自定义特性需要创建一个继承自System.Attribute的类,同时可以为其添加构造函数和属性来存储额外的元数据信息。定义自定义特性时,通常还会通过AttributeUsage特性来限制该特性的使用范围。

using System;

// AttributeUsage指定该特性只能用于类和方法上,AllowMultiple表示是否允许同一个元素多次使用该特性
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, AllowMultiple = false)]
public class AuthorAttribute : Attribute
{
    // 特性类的公共属性,用于存储元数据
    public string Name { get; set; }
    public string Version { get; set; }

    // 特性的构造函数,支持位置参数
    public AuthorAttribute(string name)
    {
        Name = name;
    }
}

特性的获取与使用

特性的元数据通常在运行时通过反射获取,下面演示如何获取自定义特性和内置特性的信息。

using System;
using System.Reflection;

// 使用自定义的Author特性,位置参数对应构造函数的参数,命名参数对应属性
[Author("张三", Version = "1.0")]
[Obsolete("该类已过时")]
public class TestClass
{
    [Author("李四", Version = "2.0")]
    public void TestMethod() { }
}

class Program
{
    static void Main()
    {
        Type type = typeof(TestClass);
        
        // 获取类上的Author特性
        AuthorAttribute classAuthor = type.GetCustomAttribute<AuthorAttribute>();
        if (classAuthor != null)
        {
            Console.WriteLine($"类的作者:{classAuthor.Name},版本:{classAuthor.Version}");
        }

        // 获取类上的Obsolete特性
        ObsoleteAttribute classObsolete = type.GetCustomAttribute<ObsoleteAttribute>();
        if (classObsolete != null)
        {
            Console.WriteLine($"类的过时信息:{classObsolete.Message}");
        }

        // 获取方法上的Author特性
        MethodInfo method = type.GetMethod("TestMethod");
        AuthorAttribute methodAuthor = method.GetCustomAttribute<AuthorAttribute>();
        if (methodAuthor != null)
        {
            Console.WriteLine($"方法的作者:{methodAuthor.Name},版本:{methodAuthor.Version}");
        }
    }
}

特性使用的注意事项

  • 特性类的命名通常以Attribute结尾,使用时可以省略后缀,比如AuthorAttribute可以直接写成Author。
  • 特性本身不会主动执行逻辑,需要通过反射主动读取特性元数据后才能实现对应的功能。
  • 通过AttributeUsage限制特性的使用范围后,如果错误地将特性用在不符合范围的元素上,编译时会直接报错。
  • 特性的构造函数参数分为位置参数和命名参数,位置参数必须对应构造函数的参数顺序,命名参数对应特性的公共属性。

C#Attribute自定义特性内置特性反射修改时间:2026-06-18 01:03:25

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。