您的位置:首页 > 编程语言 > Java开发

Java深入(高新技术)(五):注解

2015-12-28 09:24 316 查看
深切怀念传智播客张孝祥老师,特将其代表作——Java基础加强视频研读两遍,受益颇丰,记以后阅

SuppressWarnings:@SuppressWarnings("deprecation")告诉编译器不要报告这个警告

Deprecated:方法或者类打上这个注解表示过时的

Override:重写方法,如果你的方法定义不符合重写,那么警告

注解相当于一种标记,在程序中加了注解就等于为程序打上了某种标记,没加,则等于没有某种标记,以后,javac编译器,开发工具和其他程序可以用反射来了解你的类及各种元素上有无何种标记,看你有什么标记,就去干相应的事。标记可以加在包,类,字段,方法,方法的参数以及局部变量上。【相当于一种修饰符,其实像什么访问修饰符也相当于注解,就是告诉别人去干某种事情,比如Deprecated表示过时的,你如果用了就给你划上删除线】

注解就相当于一个你的源程序中要调用的一个类,要在源程序中应用某个注解,得先准备好了这个注解类。就像你要调用某个类,得先有开发好这个类。



对应用了注解的类,反射获取这个类的注解,调用注解的方法。【注解类】【应用注解类的类】【对应用了注解类的类进行反射操作的类《一般是javac编译器、开发工具、其他程序反射,前两者也是通过反射获取的》】

 

定义一个最简单的注解:public @interface MyAnnotation {}

把它加在某个类上:@MyAnnotation public class AnnotationTest{}

用反射进行测试AnnotationTest的定义上是否有@MyAnnotation

根据发射测试的问题,引出@Retention元注解的讲解,其三种取值:RetetionPolicy.SOURCE、RetetionPolicy.CLASS、RetetionPolicy.RUNTIME;分别对应:java源文件-->class文件-->内存中的字节码。【注解的生命周期】

@Override【SOURCE】、@SuppressWarnings【SOURCE】和@Deprecated【RUNTIME】

@Target的默认值为任何元素,设置Target等于ElementType.METHOD,原来加在类上的注解就报错了,改为用数组方式设置{ElementType.METHOD,ElementType.TYPE}就可以了,Type是比Class更高级的,比如注解、接口、Class都是Type。

@Retention(RetentionPolicy.RUNTIME)

@Target({ElementType.METHOD,ElementType.TYPE})

public @interface MyAnnotation {

     String color() default"yellow";

     String value() ;

     int [] arrayAttr()default {1,2};

     EnumTest.TrafficLamplamp() default EnumTest.TrafficLamp.RED;

     MetaAnnotationannotationAttr() default @MetaAnnotation("xxx");

}

 

if(ReflectPoint.class.isAnnotationPresent(MyAnnotation.class)) {

                     System.out.println(AnnotationTest.class.getAnnotation(MyAnnotation.class)

                 );

 

l  什么是注解的属性

Ø  一个注解相当于一个胸牌,如果你胸前贴了胸牌,就是传智播客的学生,否则,就不是。如果还想区分出是传智播客哪个班的学生,这时候可以为胸牌在增加一个属性来进行区分。加了属性的标记效果为:@MyAnnotation(color="red")

l  定义基本类型的属性和应用属性:

Ø  在注解类中增加String color();

Ø  @MyAnnotation(color="red")

l  用反射方式获得注解对应的实例对象后,再通过该对象调用属性对应的方法

Ø  MyAnnotation a =(MyAnnotation)AnnotationTest.class.getAnnotation(MyAnnotation.class);

Ø  System.out.println(a.color());

Ø  可以认为上面这个@MyAnnotation是MyAnnotaion类的一个实例对象

l  为属性指定缺省值:

Ø  String color() default "yellow";

l  value属性:

Ø  String value() default "zxx";

Ø  如果注解中有一个名称为value的属性,且你只想设置value属性(即其他属性都采用默认值或者你只有一个value属性),那么可以省略value=部分,例如:@MyAnnotation("lhm")。

l  数组类型的属性

Ø  int []arrayAttr()default {1,2,3};

Ø  @MyAnnotation(arrayAttr={2,3,4})

Ø  如果数组属性中只有一个元素,这时候属性值部分可以省略大括

l  枚举类型的属性

Ø  TrafficLamp lamp() ;

Ø  @MyAnnotation(lamp= TrafficLamp.GREEN)

l  注解类型的属性:

Ø  MetaAnnotation annotationAttr()default@MetaAnnotation("xxxx");

Ø  @MyAnnotation(annotationAttr=@MetaAnnotation(“yyy”))

Ø  可以认为上面这个@MyAnnotation是MyAnnotaion类的一个实例对象,同样的道理,可以认为上面这个@MetaAnnotation是MetaAnnotation类的一个实例对象,调用代码如下:

       MetaAnnotationma =  myAnnotation.annotationAttr();

       System.out.println(ma.value());

l  注解的属性类型可以是:基本数据类型,String,Class【String.class】,枚举,其他注解,以及这些类型的数组。【Java
Language Spectificatiion】

l  其实说白了,注解就是传递一个信息的,所以在以后有可能能够代替xml文档
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: