首页 > 编程语言 > 详细

Java 注解(Annotation)

时间:2020-06-06 14:34:02      阅读:54      评论:0      收藏:0      [点我收藏+]

Java 注解(Annotation)又称 Java 标注,是 JDK5.0 引入的一种注释机制。

 

定义一个注解的方式:

 @Target(ElementType.METHOD)
 @Retention(RetentionPolicy.RUNTIME)
 public @interface Test {
   String value() default "helloWorld";
}

 

内置的注解

Java 定义了一套注解,共有 7 个,3 个在 java.lang 中,剩下 4 个在 java.lang.annotation 中。

作用在代码的注解是

  • @Override - 检查该方法是否是重写方法。如果发现其父类,或者是引用的接口中并没有该方法时,会报编译错误。
  • @Deprecated - 标记过时方法。如果使用该方法,会报编译警告。
  • @SuppressWarnings - 指示编译器去忽略注解中声明的警告。

作用在其他注解的注解(或者说 元注解)是:

  • @Retention - 标识这个注解怎么保存,是只在代码中,还是编入class文件中,或者是在运行时可以通过反射访问。
  • @Documented - 标记这些注解是否包含在用户文档中。
  • @Target - 标记这个注解应该是哪种 Java 成员。
  • @Inherited - 标记这个注解是继承于哪个注解类(默认 注解并没有继承于任何子类)

从 Java 7 开始,额外添加了 3 个注解:

  • @SafeVarargs - Java 7 开始支持,忽略任何使用参数为泛型变量的方法或构造函数调用产生的警告。
  • @FunctionalInterface - Java 8 开始支持,标识一个匿名函数或函数式接口。
  • @Repeatable - Java 8 开始支持,标识某注解可以在同一个声明上使用多次。

 

 

通过Junit执行过程理解反射和注解的使用场景

package reflect;
import org.junit.Test;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;

public class JunitTest {

    @Test
    public void hello(){
        System.out.println("helloWorld");
    }

    /**
     * junit单元测试执行过程
     * @param args
     * @throws InvocationTargetException
     * @throws IllegalAccessException
     */
    public static void main(String[] args) throws InvocationTargetException, IllegalAccessException {
        //创建测试类对象
        JunitTest test = new JunitTest();
        //获取测试类所对应的class对象
        Class<? extends JunitTest> aClass = test.getClass();
        //利用反射获取该类所有的方法组成的数组
        Method[] declaredMethods = aClass.getDeclaredMethods();
        //遍历方法数组,判断每一个方法上是否存在Test注解,如果存在,则调用该方法
        for (Method method:declaredMethods) {
            if (method.isAnnotationPresent(Test.class)){
                method.invoke(Test.class ,new Object[]{});
            }
        }
    }
}

 

 

 

 

@Target

表示该注解可以用于什么地方,可能的ElementType参数有:

CONSTRUCTOR:构造器的声明

FIELD:域声明(包括enum实例)

LOCAL_VARIABLE:局部变量声明

METHOD:方法声明

PACKAGE:包声明

PARAMETER:参数声明

TYPE:类、接口(包括注解类型)或enum声明

@Retention

表示需要在什么级别保存该注解信息。可选的RetentionPolicy参数包括:

SOURCE:注解将被编译器丢弃

CLASS:注解在class文件中可用,但会被VM丢弃

RUNTIME:VM将在运行期间保留注解,因此可以通过反射机制读取注解的信息。

@Document 将注解包含在Javadoc中
@Inherited 允许子类继承父类中的注解

Java 注解(Annotation)

原文:https://www.cnblogs.com/karinemo/p/13054319.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!