这里有新鲜出炉的 Java 设计模式,程序狗速度看过来!
java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的 Java 程序设计语言和 Java 平台(即 JavaEE(j2ee), JavaME(j2me), JavaSE(j2se))的总称。
这篇文章主要介绍了 java @interface 注解详解及实例的相关资料, 需要的朋友可以参考下
java @interface 注解详解及实例
1 简介
在 Java 中,定义注解其实和定义接口差多不,只需要在 interface 前添加一个 @符号就可以,即 @interface Zhujie{ },这就表明我们定义了一个名为 @Zhujie 的注解。注解中的每一个方法定义了这个注解类型的一个元素,特别注意:注解中方法的声明中一定不能包含参数,也不能抛出异 常;方法的返回值被限制为简单类型、String、Class、emnus、注释,和这些类型的数组,但方法可以有一个缺省值。
注解相当于一种标记,在程序中加上了注解就等于为程序加上了某种标记,JAVAC 编译器、开发工具和其他程序可以用反射机制来了解咱们的类以及各种元素上有无标记,如果找到标记,就做相应的事。例如,@Deprecated 可以标记在一些不建议被使用的类、方法和字段上,如果有人使用了,就给出警告。
2 元注解
注解 @Retention 可以用来修饰注解,是注解的注解,称为元注解。Retention 注解有一个属性 value,是 RetentionPolicy 类型的,而 Enum RetentionPolicy 是一个枚举类型,这就决定了 Retention 注解应该如何去操作,也可以理解为 Rentention 搭配 RententionPolicy 来使用。RetentionPolicy 有 3 个值,分别为:CLASS 、RUNTIME 和 SOURCE。
3 使用示例
首先,创建一个简单的注解:
- public @interface Coder {
- int personId();
- String company() default "[unassigned]";
- }
注解定义完之后,咱们就可以用来作注释声明。注解是一种特殊的修饰符,在其他修饰符(例如,public、static 或者 final 等)使用地方都可以使用注解。按照惯例,注解应该放在其他修饰符的前面。注解的声明用 @符号后面跟上这个注解类型的名字,再后面加上括号,括号中列出这个注释中元素或者方法的 key-value 对,其中,值必须是常量。例如:
- @coder(personId = 20151120, company = "YeePay")
没有元素或者方法的注解被称为 "标记(marker)" 类型,例如:
- public@interface Coder {}
标记注解在使用的时候,其后面的括号可以省略。如果注释中仅包含一个元素,这个元素的名字应该为 value,例如:
- public @interface Coder {
- String value();
- }
如果元素的名字为 value,那么在使用这个注解的时候,元素的名字和等号都可以省略,例如:
- @Coder("YeePay")
来源: http://www.phperz.com/article/17/0826/338478.html