------- <a href="http://www.itheima.com" target="blank">android培训</a>、<a href="http://www.itheima.com" target="blank">java培训</a>、期待与您交流! ----------
(1)@SuppressWarnings(“derecation”)
这个注解能去除System.runFinalizesOnExit(true);中的警告
(2)@Deprecated
@Deprecated
//把方法声明过时
public static void sayHello(){
System.out.println("hi,World");
}
在另外一个类中调用这个方法就会提示过时
(3)@Override
如果方法不是重写父类中的方法,加上这个注解,编译时就会报错
(4)总结:
注解相当于一种标记,在程序中加了注解就相当于为程序打上了某种标记,没加,则等于没有某种标记。以后,javac编译器,开发工具和其他程序可以用反射来了解你的类以及各种元素上有无何种标记,看你有什么标记,就去干相应的事。标记可以加在包,类,字段,方法,方法的参数以及局部变量上。
(5) 元注解:用于定义注解的注解
@Retention属性的三个取值用来表示修饰的注解存在的位置
@Retention(RetentionPolicy.SOURCE)—java源文件
@Retention(RetentionPolicy.CLASS)—class文件
@Retention(RetentionPolicy.RUNTIME)—内存中的字节码
@Target此注解定义注解加在哪个成分上
@Target({ElementType.METHOD,ElementType.TYPE})
(6)
为注解增加基本属性
String color()default"blue";//定义一个属性,返回字符串,定义默认值blue
String value();
为注解增加高级属性
A,数组类型的属性
int[] arrayAttr() default{1,2,3};
@MyAnnotation(arrayAttr={2,3,4})
如果数组属性中只有一个元素,这时候属性值的部分可以省略大括号
B,枚举类型的属性
EnumTest.TrafficLamp.lamp();
@MyAnnotation(lamp=EnumTest.TrafficLamp.GREEN)
C,注解类型的属性
MetaAnnotation annotationAttr() default @MetaAnnotation(“xxxx”);
@MyAnnoation(annotationAttr=@MetaAnnotation(“yyyy”))
可以认为上面这个@MyAnnotation是MetaAnnotation类的一个实例对象,同样的道理,可以认为上面这个@MetaAnnotation是MetaAnnotation类的一个实例对象