预定义特性 AttributeUsage 描述了如何使用一个自定义特性类。它规定了特性可应用到的项目的类型。
规定该特性的语法如下:
[AttributeUsage(
validon,
AllowMultiple=allowmultiple,
Inherited=inherited
)]
validon:自定义特性的对象,可以是类、方法、属性等对象(默认值是 AttributeTargets.All)AttributeTargets 所有类型如下 可以使用 或运算符 |
AttributeTargets.All = AttributeTargets.Assembly | AttributeTargets.Module 等所有组合
[Flags]public enum AttributeTargets{Assembly = 1,Module = 2,Class = 4,Struct = 8,Enum = 16,Constructor = 32,Method = 64,Property = 128,Field = 256,Event = 512,Interface = 1024,Parameter = 2048,Delegate = 4096,ReturnValue = 8192,GenericParameter = 16384,All = 32767}
AllowMultiple:是否允许被多次使用(默认值为false:单用的)
Inherited:是否可被派生类继承(默认值为false:不能)
定义如下
using System;// 定义一个 NpcAttribute,
// AttributeTargets.Class标记为类Class 使用
// AllowMultiple = true 可以多次使用
// Inherited = true 可以被继承/派生子类
[AttributeUsage(AttributeTargets.Class, AllowMultiple = true, Inherited = true)]
public class NpcAttribute : Attribute
{public NpcAttribute(){}
}
使用如下
// 标记 NpcClass 类使用 NpcAttribute 属性
[Npc]
public class NpcClass
{
}
NpcClassExtend 继承 NpcClass
public class NpcClassExtend : NpcClass
{
}
标记了属性,如何使用、获取如下
private void NpcTest(){// 实例一个对象NpcClass npcClass = new NpcClass();// 获取对象类型Type t = npcClass.GetType();// 打印类型名Debug.LogError("t.Name:" + t.Name);// 获取 typeof(NpcAttribute) 属性, true 包含继承的object[] objAttrs = t.GetCustomAttributes(typeof(NpcAttribute), true);if (null != objAttrs && objAttrs.Length > 0){for (int i = 0; i < objAttrs.Length; ++i){object temp = objAttrs[i];// 类型转换NpcAttribute npcAttribute = temp as NpcAttribute;// 获取类型Debug.LogError("NpcClass 获取到 NpcAttribute:" + npcAttribute.ToString());}}else{Debug.LogError("NpcClass 未找到 NpcAttribute");}// 上面执行打印结果// t.Name:NpcClass// NpcClass 获取到 NpcAttribute:NpcAttribute}private void NpcExtendTest(){// 实例一个对象NpcClassExtend npcClassExtend = new NpcClassExtend();// 获取对象类型Type t = npcClassExtend.GetType();// 打印类型名Debug.LogError("t.Name:" + t.Name);// 获取 typeof(NpcAttribute) 属性, true 包含继承的object[] objAttrs = t.GetCustomAttributes(typeof(NpcAttribute), false);if (null != objAttrs && objAttrs.Length > 0){for (int i = 0; i < objAttrs.Length; ++i){object temp = objAttrs[i];// 类型转换NpcAttribute npcAttribute = temp as NpcAttribute;// 获取类型Debug.LogError("NpcClassExtend 获取到 NpcAttribute:" + npcAttribute.ToString());}}else{Debug.LogError("NpcClassExtend 未找到 NpcAttribute");}// 上面执行打印结果// t.Name:NpcClassExtend// NpcClassExtend 获取到 NpcAttribute:NpcAttribute// 如果上面代码修改,第二个参数 inherit 为 false// object[] objAttrs = t.GetCustomAttributes(typeof(NpcAttribute), false);// 执行打印结果// t.Name:NpcClassExtend// NpcClassExtend 未找到 NpcAttribute// 因为 NpcClass 标记了[Npc],NpcClassExtend 继承了 NpcClass// 获取时如果函数 GetCustomAttributes(Type attributeType, bool inherit)中 inherit 赋值为 false// 则 NpcClassExtend 无法获取到 NpcAttribute 属性}
修改
// Inherited = false 不允许派生、继承
[AttributeUsage(AttributeTargets.Class, AllowMultiple = true, Inherited = false)]
public class NpcAttribute : Attribute
{public NpcAttribute(){}
}
下面获取的 objAttrs 中是获取不到 NpcAttribute 的
// 实例一个对象NpcClassExtend npcClassExtend = new NpcClassExtend();// 获取对象类型Type t = npcClassExtend.GetType();// 打印类型名Debug.LogError("t.Name:" + t.Name);// 获取 typeof(NpcAttribute) 属性, true 包含继承的object[] objAttrs = t.GetCustomAttributes(typeof(NpcAttribute), true);
AllowMultiple = true 作用,允许多次使用,代码如下
[Npc]
[Npc]
[Npc]
public class NpcClass
{}
private void NpcTest(){// 实例一个对象NpcClass npcClass = new NpcClass();// 获取对象类型Type t = npcClass.GetType();// 打印类型名Debug.LogError("t.Name:" + t.Name);// 获取 typeof(NpcAttribute) 属性, true 包含继承的object[] objAttrs = t.GetCustomAttributes(typeof(NpcAttribute), true);if (null != objAttrs && objAttrs.Length > 0){for (int i = 0; i < objAttrs.Length; ++i){object temp = objAttrs[i];// 类型转换NpcAttribute npcAttribute = temp as NpcAttribute;// 获取类型Debug.LogError("NpcClass 获取到 NpcAttribute:" + npcAttribute.ToString());}}else{Debug.LogError("NpcClass 未找到 NpcAttribute");}// 上面执行打印结果// t.Name:NpcClass// NpcClass 获取到 NpcAttribute:NpcAttribute// NpcClass 获取到 NpcAttribute:NpcAttribute// NpcClass 获取到 NpcAttribute:NpcAttribute}
上面代码打印了三行 NpcClass 获取到 NpcAttribute:NpcAttribute,是因为NpcClass使用了三次标记[Npc]
修改代码,将 AllowMultiple 赋值为 false
[AttributeUsage(AttributeTargets.Class, AllowMultiple = false, Inherited = false)]
public class NpcAttribute : Attribute
{public NpcAttribute(){}
}
则 NpcClass 报错,多次使用了 Npc 属性
Assets\Script\NpcClass.cs(6,2): error CS0579: Duplicate ‘Npc’ attribute
定义可传参数的属性,修改代码如下
using System;[AttributeUsage(AttributeTargets.Class, AllowMultiple = true, Inherited = true)]
public class NpcAttribute : Attribute
{private string _descript;public NpcAttribute(string descript){_descript = descript;}public string Descript{get { return _descript; }}
}[Npc("Npc 添加一次 ")]
[Npc("Npc 添加二次 ")]
[Npc("Npc 添加三次 ")]
public class NpcClass
{
}public class NpcClassExtend : NpcClass
{}private void NpcTest(){// 实例一个对象NpcClass npcClass = new NpcClass();// 获取对象类型Type t = npcClass.GetType();// 打印类型名Debug.LogError("t.Name:" + t.Name);// 获取 typeof(NpcAttribute) 属性, true 包含继承的object[] objAttrs = t.GetCustomAttributes(typeof(NpcAttribute), true);if (null != objAttrs && objAttrs.Length > 0){for (int i = 0; i < objAttrs.Length; ++i){object temp = objAttrs[i];// 类型转换NpcAttribute npcAttribute = temp as NpcAttribute;// 获取类型Debug.LogError("NpcClass 获取到 NpcAttribute:" + npcAttribute.ToString() + " " + npcAttribute.Descript);}}else{Debug.LogError("NpcClass 未找到 NpcAttribute");}// 上面执行打印结果// t.Name:NpcClass// NpcClass 获取到 NpcAttribute:NpcAttribute Npc 添加一次 // NpcClass 获取到 NpcAttribute:NpcAttribute Npc 添加二次 // NpcClass 获取到 NpcAttribute:NpcAttribute Npc 添加三次 }private void NpcExtendTest(){// 实例一个对象NpcClassExtend npcClassExtend = new NpcClassExtend();// 获取对象类型Type t = npcClassExtend.GetType();// 打印类型名Debug.LogError("t.Name:" + t.Name);// 获取 typeof(NpcAttribute) 属性, true 包含继承的object[] objAttrs = t.GetCustomAttributes(typeof(NpcAttribute), true);if (null != objAttrs && objAttrs.Length > 0){for (int i = 0; i < objAttrs.Length; ++i){object temp = objAttrs[i];// 类型转换NpcAttribute npcAttribute = temp as NpcAttribute;// 获取类型Debug.LogError("NpcClassExtend 获取到 NpcAttribute:" + npcAttribute.ToString() + " " + npcAttribute.Descript);}}else{Debug.LogError("NpcClassExtend 未找到 NpcAttribute");}// 上面执行打印结果// t.Name:NpcClassExtend// NpcClassExtend 获取到 NpcAttribute:NpcAttribute Npc 添加一次 // NpcClassExtend 获取到 NpcAttribute:NpcAttribute Npc 添加二次 // NpcClassExtend 获取到 NpcAttribute:NpcAttribute Npc 添加三次 }