本文主要是介绍Java注解初探,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
什么是注解
注解(Annotation)是从JDK5开始引入的一个概念,其实就是代码里的一种特殊标记。这些标记可以在编译,类加载,运行时被读取,并执行相应的处理。通过注解开发人员可以在不改变原有代码和逻辑的情况下在源代码中嵌入补充信息。有了注解,就可以减少配置文件,现在越来越多的框架已经大量使用注解,而减少了XML配置文件的使用,尤其是Spring,已经将注解玩到了极致。
注解与XML配置各有优缺点:注解提高了效率,但同时也增加了代码的耦合度。XML配置降低了耦合度,但是也降低了效率。
Java提供了5个基本的注解,但是咱们编程中常用的有三个,分别是:
- @Override:这个咱们见到的最多,用来限定父类重写方法。当子类重写父类方法,或者实现接口时,子类方法或者实现类的方法可以加上这个注解,这样IDE就会检查这个方法是否和父类或者接口的方法签名一致,确保子类或者实现类确实重写了父类的方法或者实现了接口中的方法,避免出现低级错误。如果子类或者实现类的方法上加了这个注解,但是方法签名和父类或者接口中的不一致,IDE会报错。如果没加这个注解,即使签名不一致,IDE也不会报错。
-
@Deprecated:用于表示某个程序类,方法等已过时,当其他程序使用已过时的类,方法时编译器会给出警告,上边会出现删除线。
-
@SuppressWarnings:用于抑制编译器警告,被该注解修饰的元素以及该元素的所有子元素取消显示编译器警告。这个对于不想看到黄色叹号的有强迫症的人比较有用,比如声明一个List时要求使用泛型指明list元素的类型,而有时没法指定(比如调用别人写好的方法,而该方法的返回值是list,且没有指定元素类型),或者我们不想指定,但是又不想看到IDE的警告,就可以用这个。
其它的两个不常用,就不做介绍了。
元注解
元注解是用来修饰其它注解的一种特殊注解。
常用的元注解包括:
-
@Retention:用来设置被修饰的注解可以保存多久,带一个参数,该参数有三个可选值:(1)、RetentionPolicy.SOURCE,表示该注解只保存在源代码中,编译器直接丢弃该注解;(2)、RetentionPolicy.CLASS,表示编译器把该注解记录在class文件中,当运行java程序时,JVM不可获取注解信息,这是默认值;(3)、RetentionPolicy.RUNTIME,表示编译器把该注解记录在class文件中,当运行java程序时,JVM可获取注解信息,程序可以通过反射获取该注解信息。
-
@Target:指定被修饰的注解能用于修饰哪些程序元素,值为一个ElementType类型的数组。常用的值包括:(1)、ElementType.TYPE:表示该注解可标注在类、接口、注解类型、枚举类型上;(2)、ElementType.FIELD:表示该注解可标注在字段上,包括枚举常量;(3)、ElementType.METHOD:表示该注解可标注在方法上;(4)、ElementType.PARAMETER:表示该注解可标注在参数上;(5)、ElementType.CONSTRUCTOR:表示该注解可标注在构造方法上;(6)、ElementType.LOCAL_VARIABLE:表示该注解可标注在局部变量上;(7)、ElementType.ANNOTATION_TYPE:表示该注解可标注在其它注解上。
-
@Documented:指定被修饰的注解类将被javadoc工具提取成文档,如果定义注解类时使用了这个注解修饰,则所有使用该注解修饰的程序API文档将会包含该注解说明。
-
@Inherited:指定被修饰的注解将具有继承性。如果父类加了这个注解,子类将自动进程父类的所有注解。
声明自定义注解
实际上单独声明一个注解是没有任何作用,或者说没有意义的。注解往往是和反射配合使用才能发挥作用。关于反射,参考我的另外一篇博文:Java中反射的实现方式。
使用@interface来声明自定义注解:
package com.huixin.annotation;import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.ElementType.TYPE;import java.lang.annotation.Documented;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;/*** 会员注解*/
@Retention(RetentionPolicy.RUNTIME)
@Target({ TYPE, FIELD, METHOD })
//@Inherited
//@Documented
public @interface MemberAnnotation {// 会员卡号String idCardNo() default "";// 会员姓名String name() default "";// 是否老板boolean isBoss() default false;
}
如果注解中有属性,则使用带括号“()”的方式来声明属性(如上边代码的第22行),看起来有点像一个方法,但是没有大括号“{}”。如果该属性有默认值的话,后边用default关键字来指定默认值。
下边写一个测试类来使用注解:
package com.huixin.annotation;@MemberAnnotation(idCardNo="610112", name="andrewlau", isBoss=true)
public class AnnotationTest {public static void main(String[] args) {MemberAnnotation ca = AnnotationTest.class.getAnnotation(MemberAnnotation.class);String idcardno = ca.idCardNo();String name = ca.name();boolean isadmin = ca.isBoss();System.out.println(idcardno + ", " + name + ", " + isadmin);}}
上述代码的注解加在类上,注解的三个属性都赋了值。第7行代码获取该类上的MemberAnnotation注解信息,第8到第10行获取注解的属性值。获取到属性之后就可以根据实际的业务来进行判断处理了。这就是一个简单的自定义注解的使用方法。
这篇关于Java注解初探的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!