注解,作为元数据的一种形式,虽不是程序的一部分,却有以下作用:
可以让编译器跳过某些检测
某些工具可以根据注解信息生成文档等
某些注解可以在运行时检查
@表示这是一个注解
@Override
注解可以包含元素,可以有值
@Author( name = "Benjamin Franklin", date = "3/27/2003" )只有一个元素时可以没有名字
@SuppressWarnings("unchecked")
没有元素时可以没有括号
@Author(name = "Jane Doe") @EBook
注解也可以有多个,规范做法是每个都单独一行
在JDK8以后,可以有重复注解:
@Author(name = "Jane Doe") @Author(name = "John Smith")
注解的类型在java.lang
或java.lang.annotation
中
也可以自定义自己的注解类型
注解通常用在定义的地方,类,字段,方法等
在JDK8以后,注解也能作为类型,称为type annotation
以前,注解是来替代注释的
首先要定义
import java.lang.annotation.*; @Documented //前面加这个可以让生成的javadoc包括这个注解信息 @interface ClassPreamble { //前面是@interface , 其实注解都是接口,而且定义时也类似接口 String author(); //元素定义 String date(); int currentRevision() default 1; //默认值 String lastModified() default "N/A"; String lastModifiedBy() default "N/A"; // Note use of array String[] reviewers();}
定义以后就可以使用了
@ClassPreamble ( //直接@注解类型 author = "John Doe", date = "3/17/2002", currentRevision = 6, lastModified = "4/12/2004", lastModifiedBy = "Jane Doe", // Note array notation reviewers = {"Alice", "Bob", "Cindy"} ) public class Generation3List extends Generation2List { // class code goes here }
java.lang
中的也就是预定义注解
@Deprecated是已过期,编译器会警告
@Override表示这是个覆盖的方法,其实不写也行,通常是个强制性提示,覆盖的不对会报错
@SuppressWarnings("deprecation")让编译器忽略某个警告
编译警告通常有两种,deprecation
和 unchecked
,unchecked会提示那些在泛型发明以前写的代码
@SuppressWarnings({"unchecked", "deprecation"})//可以写多个
@SafeVarargs和@FunctionalInterface ( 新)
有的注解是用于其他注解的,这称为元注解,通常在java.lang.annotation
里
@Retention
@Documented
@Target
@Inherited
@Repeatable