news 2026/4/15 10:54:29

深入理解Java注解(从零开始手把手教你自定义与使用Java注解)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
深入理解Java注解(从零开始手把手教你自定义与使用Java注解)

在Java开发中,Java注解(Annotation)是一种强大的元数据工具,它允许开发者在代码中添加额外的信息,而不会直接影响程序逻辑。无论是Spring框架中的@Autowired,还是JPA中的@Entity,都离不开注解的支持。本教程将带你从零开始,深入浅出地掌握自定义注解的创建、使用和处理。

什么是Java注解?

Java注解是从JDK 5开始引入的一种语法特性,用于为代码提供元数据(metadata)。这些元数据可以被编译器、开发工具或运行时环境读取并处理。

内置注解 vs 自定义注解

Java提供了一些内置注解,如:

  • @Override:表示方法重写了父类方法
  • @Deprecated:标记过时的代码
  • @SuppressWarnings:抑制编译器警告

但很多时候我们需要自己的业务逻辑注解,这就需要使用自定义注解

第一步:定义一个自定义注解

要创建自定义注解,我们使用@interface关键字。下面是一个简单的权限控制注解示例:

public @interface RequirePermission { String value() default "user"; boolean required() default true;}

这个注解包含两个元素:valuerequired,都有默认值,使用时可省略。

第二步:理解Java元注解

为了让自定义注解具备特定行为,我们需要用到Java元注解(Meta-Annotations),即“注解的注解”。常用的元注解有:

  • @Target:指定注解可以用在哪些程序元素上(如方法、类、字段等)
  • @Retention:指定注解的生命周期(SOURCE / CLASS / RUNTIME)
  • @Documented:是否包含在JavaDoc中
  • @Inherited:是否可被子类继承

完善我们的注解:

import java.lang.annotation.*;@Target(ElementType.METHOD) // 只能用于方法@Retention(RetentionPolicy.RUNTIME) // 运行时保留,可通过反射读取@Documentedpublic @interface RequirePermission { String value() default "user"; boolean required() default true;}

第三步:使用自定义注解

现在可以在方法上使用这个注解了:

public class UserService { @RequirePermission(value = "admin", required = true) public void deleteUser(Long userId) { System.out.println("删除用户: " + userId); } @RequirePermission public void viewProfile() { System.out.println("查看个人资料"); }}

第四步:通过反射读取注解(注解处理器)

要让注解真正“生效”,我们需要编写注解处理器。通常在框架或AOP中实现,这里用简单反射演示:

import java.lang.reflect.Method;public class AnnotationProcessor { public static void main(String[] args) throws Exception { Class<UserService> clazz = UserService.class; Method[] methods = clazz.getDeclaredMethods(); for (Method method : methods) { if (method.isAnnotationPresent(RequirePermission.class)) { RequirePermission anno = method.getAnnotation(RequirePermission.class); System.out.println("方法 " + method.getName() + " 需要权限: " + anno.value() + ", 是否必需: " + anno.required()); } } }}

运行结果:

方法 deleteUser 需要权限: admin, 是否必需: true方法 viewProfile 需要权限: user, 是否必需: true

总结

通过本教程,你已经掌握了:

  • 如何定义Java注解
  • 如何使用Java元注解控制注解行为
  • 如何在代码中应用自定义注解
  • 如何通过反射实现简单的注解处理器

注解是现代Java框架(如Spring、Hibernate)的核心机制之一。掌握它,你就离高级Java开发更近了一步!

来源:https://www.vpshk.cn/https://www.vpshk.cn/

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/13 19:56:11

Open-AutoGLM上手机,只需这4步!开发者必看的轻量化部署秘籍

第一章&#xff1a;Open-AutoGLM移动端部署概述Open-AutoGLM 是基于 AutoGLM 架构优化的轻量化大语言模型&#xff0c;专为在移动设备上实现高效推理而设计。该模型通过结构压缩、算子融合与硬件适配等技术&#xff0c;在保持较高自然语言理解能力的同时&#xff0c;显著降低计…

作者头像 李华
网站建设 2026/4/8 7:24:06

【大模型私有化部署新选择】:Open-AutoGLM本地化实施方案详解

第一章&#xff1a;Open-AutoGLM私有化部署的背景与意义随着企业对数据隐私和模型可控性的要求日益提升&#xff0c;大语言模型的私有化部署逐渐成为关键需求。Open-AutoGLM 作为一款开源的自动化生成语言模型&#xff0c;支持在本地环境或私有云中部署&#xff0c;确保敏感数据…

作者头像 李华
网站建设 2026/4/7 14:54:12

零代码+全场景!ChatWiki四步搭建企业AI知识库,效率提升必备收藏指南

传统知识管理因知识分散导致查找效率低、响应慢。ChatWiki作为零代码AI知识库解决方案&#xff0c;通过接入大模型、上传文档处理、关联知识库和智能响应四步&#xff0c;帮助企业构建智能记忆中枢。其全场景适配和精细化管理功能&#xff0c;使企业能高效利用AI技术提升知识管…

作者头像 李华
网站建设 2026/4/8 0:45:42

openEuler 系统想远程管理?不用公网 IP 也能轻松实现,方法在这!

文章目录前言1. 本地SSH连接测试2. openEuler安装Cpolar3. 配置 SSH公网地址4. 公网远程SSH连接5. 固定连接SSH公网地址6. SSH固定地址连接测试前言 openEuler 是一款聚焦多样性计算的操作系统&#xff0c;支持服务器、嵌入式设备和云计算环境&#xff0c;安全性和稳定性都不错…

作者头像 李华
网站建设 2026/4/8 7:23:20

Mac上运行Open-AutoGLM到底难不难?看完这篇你就知道该怎么做

第一章&#xff1a;Mac上运行Open-AutoGLM的现状与挑战在苹果芯片架构逐步普及的背景下&#xff0c;越来越多开发者尝试在Mac平台上部署和运行大型语言模型。Open-AutoGLM作为基于AutoGPT架构衍生的开源项目&#xff0c;具备自动化任务分解与执行能力&#xff0c;但其在Mac本地…

作者头像 李华