Java注解(Annotation)
一、元注解()
@Target 表示该注解用于什么地方,可能的值在枚举类 ElemenetType 中
@Retention 表示在什么级别保存该注解信息。可选的参数值在枚举类型 RetentionPolicy 中
@Documented 将此注解包含在 javadoc 中 ,它代表着此注解会被javadoc工具提取成文档。在doc文档中的内容会因为此注解的信息内容不同而不同。相当与@see,@param 等。
@Inherited 允许子类继承父类中的注解。
1、@Target包括:
ElemenetType.TYPE----------------------------------- 类,接口(包括注解类型)或enum声明
ElemenetType.METHOD ---------------------------------方法声明
ElemenetType.CONSTRUCTOR-----------------------------构造器声明
ElemenetType.FIELD ----------------------------------域声明(包括 enum 实例)
ElemenetType.LOCAL_VARIABLE------------------------- 局部变量声明
ElemenetType.PACKAGE --------------------------------包声明
ElemenetType.PARAMETER ------------------------------参数声明
2、@Retention包括:
RetentionPolicy.SOURCE-------------注解将被编译器丢弃
RetentionPolicy.CLASS -------------注解在class文件中可用,但会被VM丢弃
<!--一般用此注解-->
RetentionPolicy.RUNTIME -----------VM将在运行期也保留注释,因此可以通过反射机制读取注解的信息。
二、内置注解(预置的注解)
@Deprecated: 标记过时的元素,调用使用@Deprecated 注解的方法后,编译器会警告提醒
@Override: 修饰需要被重写的方法
@SuppressWarnings 阻止警告,如:在某方法上使用@SuppressWarnings("deprecation")
三、自定义注解
注解通过 @interface 关键字进行定义。
public @interface TestAnnotation {
}
四、Annotation 的作用
- 标记,用于告诉编译器一些信息
- 编译时动态处理,如动态生成代码,动态添加逻辑
- 运行时动态处理,如得到注解信息
五、注解与反射
public boolean isAnnotationPresent(Class<? extends Annotation> annotationClass) {} public <A extends Annotation> A getAnnotation(Class<A> annotationClass) {} public Annotation[] getAnnotations() {}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix