黑马程序员--注解类

               ------------android培训java培训、期待与您交流!--------------

大纲:

      一、注解类概述

      二、java提供的几个基本注解

      三、注解的定义与反射调用

      四、注解属性

      五、高级注解属性

      

一、注解类概述

注解相当于一种标记,在程序中加了注解就等于为程序打上了某种标记,没加,则等于没有某种标记,以后,javac编译器,开发工具和其他程序可以用反射来了解你的类及各种元素上有无何种标记,看你有什么标记,就去干相应的事。标记可以加在包,类,字段,方法,方法的参数以及局部变量上。一个注解就是一个类,使用注解,就相当于创建了一个对象。

二、java提供的几个基本注解

1、@SuppressWarnings
示例:

package com.itheima.day2;
public class AnnotationTest {
       publicstaticvoidmain(String[] args) {
            System.runFinalizersOnExit(true);     
      }
}
由上面的示例可以看到当执行一切过时的方法时,eclipse会自动划线, 提示开发人员调用的方法已经过时,建议不要调用。
此时,在main方法上添加一个注解:@SuppressWarnings("deprecation"),
此注解的作用就是告诉编译器,虽然我用的方法过时了,但是我还是坚持要用,
你就不要再提示了。
示例:
package com.itheima.day2;
public class AnnotationTest {
       @SuppressWarnings("deprecation")
       publicstaticvoidmain(String[] args) {
            System.runFinalizersOnExit(true);     
      }
}
再在命令行窗口中进行编译,就不会出现过时提示了。

2、@Deprecated

有时候我们写的方法被别人调用了,但是如果这个方法有一些bug需要修改, 可是如果我们修改了又会影响以前已经调用这个方法的程序。 这时候我们可以把这个方法设置为过时,然后重新写一个方法,这时候就
需要用到@Deprecated注解。
示例:
package com.itheima.day2;
public class AnnotationTest {
       public static void main(String[] args) {
            sayHello();
      }
       @Deprecated
      publicstaticvoidsayHello(){
            System.out.println("hi,heima,I'm coming!" );
      }
}

由上面的示例可以看到,我们的sayHello方法可以通过@Deprecated注解标记为过时,
然后调用者调用该方法的地方就会被eclipse划上横线作为过时的提示。
3、@Override
有时候我们写的某些方法需要覆盖父类的方法,但是可能方法名或者参数
会出现不小心写错的情况。这时候就可以为这个方法打上@Override注解,
如果有任何差错,eclipse就会报错。
例如equals方法的参数为Object obj,但是经常会被写错,
这时候就可以通过@Override注解避免这种情况。

三、注解的定义与反射调用

注解的应用结构图:



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

定义注解类:

public @interface ItheimaAnnotation {
}
对注解类进行调用:

@ItheimaAnnotation
public class AnnotationTest {
       public static void main(String[] args) {
             if(AnnotationTest.class.isAnnotationPresent(ItheimaAnnotation. class)){
                   ItheimaAnnotation itheimaAnnotation = AnnotationTest.class .getAnnotation(ItheimaAnnotation. class);
                  System. out.println(itheimaAnnotation);
            }
      }
}

执行之后,控制台并没有打印出任何信息,原因是因为@ItheimaAnnotation注解的 RetentionPolicy元注解默认值是 RetentionPolicy.CLASS,也就是说 @ItheimaAnnotation 注解 在运行的时候已经被过滤掉了。解决这个问题的方式就是将 @ItheimaAnnotation RetentionPolicy元注解值设置为 RetentionPolicy.RUNTIME。

修改后的注解类:

import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
@Retention(RetentionPolicy.RUNTIME)
public @interface ItheimaAnnotation {
}

@Retention(RetentionPolicy.RUNTIME)就是元注解
注意:
元注解就是在注解上添加的注解
@Retention元注解有三种取值:RetetionPolicy.SOURCE、RetetionPolicy.CLASS、RetetionPolicy.RUNTIME,分别对应:java源文件-->class文件-->内存中的字节码。

另一元注解Target:
Target的默认值为任何元素,设置Target等于ElementType.METHOD,原来加在类上的注解就报错了。
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface ItheimaAnnotation {
}
改为用数组方式设置{ElementType.METHOD,ElementType.TYPE}就不会报错了。

四、注解属性

1、注解属性定义:

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

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

 在注解类中增加String color(); 被添加的注解设置属性值:@MyAnnotation(color="red")

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

MyAnnotation a = (MyAnnotation)AnnotationTest.class.getAnnotation(MyAnnotation.class);
System.out.println(a.color());
可以认为上面这个@MyAnnotation是MyAnnotaion类的一个实例对象

4、为属性指定缺省值:String color() default "yellow";

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

五、高级注解属性

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

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

示例代码:

public @interface MetaAnnotation {
      String value();
}

@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD,ElementType.TYPE})
public @interface ItheimaAnnotation {
      String color() default "blue" ;
      String value();
      int[] arrayAttr() default {1};
      EnumTest.TrafficLamp lamp() default EnumTest.TrafficLamp.RED;
      MetaAnnotation annotationAttr() default @MetaAnnotation( "lhm");
      Class clazz() default String.class;
}


@ItheimaAnnotation(annotationAttr=@MetaAnnotation ("flx" ),color="red",value= "abc",arrayAttr={1,2,3})
public class AnnotationTest {
       @ItheimaAnnotation("xyz" )
       public static void main(String[] args) {
             if(AnnotationTest.class.isAnnotationPresent(ItheimaAnnotation. class)){
                   ItheimaAnnotation itheimaAnnotation = AnnotationTest.class .getAnnotation(ItheimaAnnotation. class);
                  System. out.println(itheimaAnnotation.color());
                   //结果:red
                  System. out.println(itheimaAnnotation.arrayAttr().length);
                   //结果:3
                  System. out.println(itheimaAnnotation.lamp().nextLamp().name());
                   //结果:GREEN
                  System. out.println(itheimaAnnotation.annotationAttr().value());
                   //结果:flx
                  System. out.println(itheimaAnnotation.clazz());
                   //结果:class java.lang.String
            }
      }
}



               ------------android培训java培训、期待与您交流!--------------

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值