Java中的注解

本文详细解读Java注解的用途、内置注解如@Override、@SuppressWarnings和@FunctionalInterface,以及如何创建和使用元注解、作用范围和保留策略。了解如何自定义注解,包括@Target、@Retention和@Repeatable,并通过反射获取注解信息。
摘要由CSDN通过智能技术生成

Java注解(Annotation)是一种表示元数据的标签,即附加在类、接口、方法或字段上,以指示Java编译器和JVM可以使用的一些附加信息。

Java中的注解用于提供附加信息,因此它是XML的另一种选择。

Java 内置注解

@Override

@Override注释确保子类方法覆盖了父类方法。如果不是这样,就会发生编译时错误。

@SuppressWarnings

@SuppressWarnings注释:用于抑制编译器发出的警告

@FunctionalInterface

java8支持,标识一个匿名函数或函数式接口

元注解

所谓元注解就是标记其他注解的注解,用于开发自定义注解

@Target

标识这个注解的作用范围

ElementType 声明了许多常量来指定注解可以作用的元素类型,比如类型、方法、字段等

Element Types注解可以作用的范围
TYPEclass, interface or enumeration
FIELDfields
METHODmethods
CONSTRUCTORconstructors
LOCAL_VARIABLElocal variables
ANNOTATION_TYPEannotation type
PARAMETERparameter
@Target({ElementType.FIELD, ElementType.METHOD})    //表示该注解可以作用在字段或方法上
public @interface MyAnnotation {
}

class Test {
    @MyAnnotation
    private String desc;

    @MyAnnotation
    public String getDesc() {
        return desc;
    }
}

@Retention

指定注解信息保留阶段,有如下三种枚举选择。只能选其一

保留策略描述
RetentionPolicy.SOURCE注解在编译过程中丢弃。生成的class不包含注解信息
RetentionPolicy.CLASS注解在class文件中可用,但会被JVM丢弃;当注解未定义Retention值时,默认值是CLASS
RetentionPolicy.RUNTIME注解信息在运行期(JVM)保留(.class也有),可通过反射机制读取注解的信息

@Repeatable

JDK1.8新加入的,表明自定义的注解可以在同一个位置重复使用。在没有该注解前,是无法在同一个类型上使用相同的注解多次

@Inherited

默认情况下,注释不会继承给子类。@Inherited表示当前注解会被注解类的子类继承

@Documented

作用是告诉JavaDoc工具,当前注解本身也要显示在Java Doc中(不常用)

自定义注解

语法

@interface MyAnnotation{
    int value();
}  

tips;

  1. 方法不应包含任何throws子句

  2. 方法应返回以下之一:原始数据类型,字符串,类,枚举或这些数据类型的数组。

  3. 方法不应具有任何参数。

  4. 我们应该在interface关键字之前附加@来定义注解。

  5. 它可以为该方法分配默认值。

@Target({ElementType.FIELD, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface MyAnnotation {
    int id() default 1001;
    String value() default "good";
}

class Test {
    @MyAnnotation(value = "not bad")
    private String desc;
}
使用反射机制获取注解信息
@Target({ElementType.FIELD, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface MyAnnotation {
    int id() default 1001;
    String value() default "good";
}

class Test {
    @MyAnnotation(value = "not bad")
    private String desc;
}

class AnnotationHandle {
    public static void main(String[] args) throws NoSuchFieldException {
        Class<Test> testClass = Test.class;
        Field desc = testClass.getDeclaredField("desc");
        MyAnnotation annotation = desc.getAnnotation(MyAnnotation.class);
        System.out.println(annotation.id());
        System.out.println(annotation.value());
    }
}

output:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值