java 元注释学习笔记

本文详细介绍了Java注解的四种核心元注解:@Retention、@Target、@Inherited 和 @Documented 的使用方法及应用场景。包括注解的保留策略、放置位置控制、继承特性以及如何将注解包含在JavaDoc中。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一.

@Retention

 

您需要将批注保留多长时间?RetentionPolicy 枚举中列出了三个选项:

选项注释示例
RetentionPolicy.SOURCE在编译过程中丢弃。编译完成后,这些批注将不起任何作用,因此不会将它们写入字节码。 @Override@SuppressWarnings
RetentionPolicy.CLASS在类加载过程中丢弃。当执行字节码级的后期处理时很有用。有些另人吃惊的是,这是默认值。-
RetentionPolicy.RUNTIME不丢弃,以便可以运行时用于反映。@Deprecated
@Retention 批注使您可以为自定义批注类型指定所需的 RetentionPolicy;它接受一个 RetentionPolicy 类型的“value”参数。
@Unfinished 示例 RetentionPolicy.RUNTIME 更有意义,您可以进行以下更改。
package com.servlets;
import java.lang.annotation.*;

@Unfinished("Just articleware")
@Documented
@Retention(RetentionPolicy.RUNTIME)
public @interface Unfinished { ...}

二.

@Target
 
现在,您要将批注放在哪里?ElementType 枚举中列出了八个选项: 
  • ElementType.TYPE (class, interface, enum) //类,接口或枚举声明
  • ElementType.FIELD (instance variable) //成员变量声明
  • ElementType.METHOD //方法声明
  • ElementType.PARAMETER //参数声明
  • ElementType.CONSTRUCTOR //构造器声明
  • ElementType.LOCAL_VARIABLE //局部变量声明
  • ElementType.ANNOTATION_TYPE (on another annotation) //其他元注释声明
  • ElementType.PACKAGE (remember package-info.java) //包声明
当您知道了可以使用的位置列表后,使用 @Target 批注(接受 ElementType 值数组)指定该位置。它只是一个整体性列表,也就说您不能排除任一位置,而是必须列出允许的七个位置。当 @Target 不存在时的默认设置是允许任何位置。@Unfinished 示例在五个位置有效,因此我们可以按如下所示指定它: 
package com.servlets;
import java.lang.annotation.*;

@Unfinished("Just articleware")
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE,ElementType.METHOD,
ElementType.CONSTRUCTOR,ElementType.ANNOTATION_TYPE,
ElementType.PACKAGE})
public @interface Unfinished { ...}

三.

@Inherited

 

最后,@Inherited 控制批注是否影响子类。例如,@Unfinished 超类是否指示未完成的子类?或许指示,因此以下是 @Unfinished 的最终格式:

package com.servlets;
import java.lang.annotation.*;

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE,ElementType.METHOD,
ElementType.CONSTRUCTOR,ElementType.ANNOTATION_TYPE,
ElementType.PACKAGE})
@Inherited
public @interface Unfinished {
public enum Priority { LOW, MEDIUM, HIGH }

String value();
String[] owners() default "";
Priority priority() default Priority.MEDIUM;
}
四.
@Documented 将注释包含在JavaDoc中
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值