Annotation
attached with class, interface, methods, fields
annotation的内容被java编译器和JVM利用
annotation用来提供额外的信息,是XML和java marker interface的替代选择
html是用来显示数据的;xml是用来描述数据、存放数据的
java marker interface:没有任何member的接口,给类做标记归类用,如Serializable, Cloneable
@Override
@Deprecated告诉编译器此method不建议使用
*@Deprecated
*简单来讲就是,若某类或某方法加上该注解之后,表示此方法或类不再建议使用,
*调用时也会出现删除线,但并不代表不能用,只是说,不推荐使用,因为还有更好的方法可以调用。
@SuppressWarning抑制警告
*抑制单类型的警告:
*@SuppressWarnings("unchecked")
*抑制多类型的警告:
*@SuppressWarnings(value={"unchecked","rawtypes"})
*抑制所有类型的警告:
*@SuppressWarnings("all")
自定义Annotation
//定义
public@interfaceAnnotationTest{
Stringvalue()default"method"
EnumTestvalue2();
}
enumEnumTest{
Class,Method
}
//调用 可用于class 也可用于method 在枚举类型中加了参数来说明
@AnnotationTest(value="class",value2=EnumTest.Class)
publicclassAnnotationClient{
@AnnotationTest(value="method",value2=EnumTest.Method)
publicvoidmethod(){
//TODO auto-generated method stub
}
}
用来标记annotation的
@Target tag is used to specify at which type, the annotation is used.
@Inherited annotation不会默认被子类继承
@Document
@Retension 定义被它所注解的注解保留多久,一共有三种策略,定义在RetentionPolicy枚举中.
@Retention(RetentionPolicy.RUNTIME)
public@interfaceMyannotation{
Stringhello();
Stringworld();
}
*source:注解只保留在源文件,当Java文件编译成class文件的时候,注解被遗弃;被编译器忽略
*class:注解被保留到class文件,但jvm加载class文件时候被遗弃,这是默认的生命周期
*runtime:注解不仅被保存到class文件中,jvm加载class文件之后,仍然存在
*这3个生命周期分别对应于:Java源文件(.java文件)--->.class文件--->内存中的字节码*默认值是class