Java可重复注解接口(Repeatable Annotation Interfaces)

Java规范参考

详细的解释可以参考Java规范:
https://docs.oracle.com/javase/specs/jls/se19/html/jls-9.html#jls-9.6.3

可重复注解接口介绍

  • 可重复注解接口是从Java 1.8版本引入的,表示可以重复出现。
  • 一个可重复注解接口A用@Repeatable修饰,并且@Repeatable的元素value 的值指明了一个A的容器注解接口。
  • 容器注解接口必须声明一个value()方法,它的返回类型是可重复注解接口类型的数组,例如A[]。
  • 在容器注解接口中声明的其它不同于value()的方法,必须有一个默认值。

例如,定义了一个可重复注解接口Name:

csharp 复制代码
package com.thb;

import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.RetentionPolicy.CLASS;

import java.lang.annotation.Documented;
import java.lang.annotation.Repeatable;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;

@Documented
@Retention(CLASS)
@Target({ TYPE, FIELD })
@Repeatable(Names.class)
public @interface Name {
    String value();
}

定义可重复注解Name接口的容器注解接口Names:

csharp 复制代码
package com.thb;

import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.RetentionPolicy.RUNTIME;

import java.lang.annotation.Documented;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;

@Documented
@Retention(RUNTIME)
@Target({ TYPE })
public @interface Names {
    Name[] value();
}
  • 容器注解接口的保留范围要至少跟可重复注解接口一样长。保留范围用@Retention显式或者隐式声明。

    1)如果容器注解接口的保留范围是java.lang.annotation.RetentionPolicy.SOURCE,那么可重复注解接口的保留范围只能是java.lang.annotation.RetentionPolicy.SOURCE。

    2)如果容器注解接口的保留范围是java.lang.annotation.RetentionPolicy.CLASS,那么可重复注解接口的保留范围可以是java.lang.annotation.RetentionPolicy.CLASS、或者java.lang.annotation.RetentionPolicy.SOURCE。

    3)如果容器注解接口的保留范围是java.lang.annotation.RetentionPolicy.RUNTIME,那么可重复注解接口的保留范围可以是java.lang.annotation.RetentionPolicy.SOURCE、或者java.lang.annotation.RetentionPolicy.CLASS、或者java.lang.annotation.RetentionPolicy.RUNTIME。

  • 可重复注解接口可以应用的程序元素类型(用@Target指明),至少要和容器注解接口可以应用的元素类型相同。假设可重复注解接口可以应用的程序元素类型集合是m1,容器注解接口可以应用的程序元素类型集合是m2,那么m2中的每个类型都必须在m1中出现,除非:

    1)如果m2中的类型是java.lang.annotation.ElementType.ANNOTATION_TYPE,那么下面三种类型必须在m1中至少出现一个:java.lang.annotation.ElementType.ANNOTATION_TYPE、 或者 java.lang.annotation.ElementType.TYPE、或者 java.lang.annotation.ElementType.TYPE_USE

    2)如果m2中的类型是java.lang.annotation.ElementType.TYPE,那么下面两种类型必须在m1中至少出现一个:java.lang.annotation.ElementType.TYPE、或者java.lang.annotation.ElementType.TYPE_USE。

    3)如果m2中的类型是java.lang.annotation.ElementType.TYPE_PARAMETER,那么下面两种类型必须在m1中至少出现一个:java.lang.annotation.ElementType.TYPE_PARAMETER、或者java.lang.annotation.ElementType.TYPE_USE。

  • 如果可重复注解接口用java.lang.annotation.Documented注解修饰,那么容器注解接口也必须用java.lang.annotation.Documented修饰。注:但容器注解接口用java.lang.annotation.Documented修饰,可重复注解接口可以不用java.lang.annotation.Documented注解修饰

  • 如果可重复注解接口用java.lang.annotation.Inherited注解修饰,那么容器注解接口也必须用java.lang.annotation.Inherited修饰。注:但容器注解接口用java.lang.annotation.Inherited修饰,可重复注解接口可以不用java.lang.annotation.Inherited注解修饰

  • @Repeatable语句不能重复出现,因此一个可重复注解接口(即被@Repeatable修饰)只能有一个容器注解接口。

  • 一个注解接口最多只能是一个注解接口的容器注解接口。

  • 一个注解接口不能声明是它本身的容器注解接口。

  • 一个容器注解接口可以有自己的容器注解接口,即:容器注解接口本身也可以是可重复注解接口。

相关推荐
小清兔2 小时前
c#基础知识
开发语言·数据库·学习·unity·c#·游戏引擎·.net
计算机学姐3 小时前
基于SpringBoot的社团管理系统【2026最新】
java·vue.js·spring boot·后端·mysql·spring·mybatis
天上掉下来个程小白3 小时前
微服务-25.网关登录校验-网关传递用户到微服务
java·数据库·微服务
奇某人3 小时前
【语法】【C+V】本身常用图表类型用法快查【CSDN不支持,VSCODE可用】
开发语言·vscode·markdown·mermaid
做一位快乐的码农4 小时前
php程序设计之基于PHP的手工艺品销售网站/基于php在线销售系统/基于php在线购物商城系统
开发语言·php
vivi_and_qiao4 小时前
HTML的form表单
java·前端·html
@珍惜一生@4 小时前
Qt开源库
开发语言·qt·开源
Slaughter信仰4 小时前
深入理解Java虚拟机:JVM高级特性与最佳实践(第3版)第四章知识点问答补充及重新排版
java·开发语言·jvm
心灵宝贝4 小时前
Mac用户安装JDK 22完整流程(Intel版dmg文件安装指南附安装包下载)
java·开发语言·macos
ta是个码农4 小时前
Mysql——日志
java·数据库·mysql·日志