注解

了解注解及java提供的几个基本注解


       注解相当于一种标记,在程序中加了注解就等于为程序打上了某种标记,没加,则等于没有某种标记,以后,javac编译器,开发工具和其他程序可以用反射来了解你的类及各种元素上有无何种标记,看你有什么标记,就去干相应的事。标记可以加在包,类,字段,方法,方法的参数以及局部变量上。
看java.lang包,可看到JDK中提供的最基本的annotation。     


当一个类中有过时的方法,在编译时会提示:XxxxXxx.java 使用或覆盖已过时的API 。
加入注解:@SuppressUarnings(“deprecaton”);
加入注解后则不会再提示。

一个注解就是一个类,相当于创建了一个实例。

当对一个类进行升级后,将一个方法标识为已过时。这时别人在调用此方法的时候,可以看到这是个已过时的方法。但不影响使用。
加入注解:@Deprecated

当覆盖父类的一个方法时,不小心将覆盖写成重载。而很难发现这个错误。在方法前添加注解:
加入注解:@Override       来标识此方法是用于覆盖的。

创建注解类:在Eclipse创建Annotation
注解类

@Retention(RetentionPolicy.RUNTIME)

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

public @interface MyAnnotation{


}


应用了注解的类
@MyAnnotation
classAnnotationTest{

}

对“应用了注解的类”进行反射操作的类
public class B{
    public static void main(String[] args) throws Exception {
        // TODO Auto-generated method stub
        if(AnnotationTest.class.isAnnotationPresent(MyAnnotation.class)){        
            MyAnnotation myAnnotation = (MyAnnotation)AnnotationTest.class.getAnnotation(MyAnnotation.class);     
            System.out.println(myAnnotation);
        }
    }
}


元注解:就是注解里面的注解

 @Retention(RetentionPolicy.RUNTIME);
 @Retention元注解的三种取值(默认的是CLASS阶段):
1.    RetentionPolicy.SOURCE:JAVA源文件
2.    RetentionPolicy.CLASS:CLASS文件
3.    RetentionPolicy.RUNTIME:内存中的字节码

Class的父接口是Type.

@Target注解
默认值为任何元素,设置Target等于ElementType.METHOD,原来加在类上的注解就报错了,改为用数组方式设置{ElementType.METHOD,ElementType.TYPE}就可以了

注解属性
l  定义基本类型的属性和应用属性:
   在注解类中增加String color();
   @MyAnnotation(color="red")

2  用反射方式获得注解对应的实例对象后,再通过该对象调用属性对应的方法
   MyAnnotationa = (MyAnnotation)AnnotationTest.class.getAnnotation(MyAnnotation.class);
   System.out.println(a.color());
   可以认为上面这个@MyAnnotation是MyAnnotaion类的一个实例对象

3  为属性指定缺省值:
   Stringcolor() default "yellow";

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

5 数组类型的属性
  int []arrayAttr() default {1,2,3};
  @MyAnnotation(arrayAttr={2,3,4})
  如果数组属性中只有一个元素,这时候属性值部分可以省略大括

6 枚举类型的属性
  EnumTest.TrafficLamp lamp() ;
  @MyAnnotation(lamp=EnumTest.TrafficLamp.GREEN)

7 注解类型的属性:
  MetaAnnotation annotationAttr() default@MetaAnnotation("xxxx");
  @MyAnnotation(annotationAttr=@MetaAnnotation(“yyy”))
  可以认为上面这个@MyAnnotation是MyAnnotaion类的一个实例对象,同样的道理,可以认为上面这个@MetaAnnotation是MetaAnnotation类的一个实例对象,调用代码如下:
       MetaAnnotation ma =  myAnnotation.annotationAttr();
       System.out.println(ma.value());


 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值