Java基础知识总结(1.8)——Java 注解(持续更新)
更新时间:2025-03-31
- Web后端专栏:CSDN专栏——理论-Web后端
- 技术博客总目录:计算机技术系列博客——目录页
8.1 注解的概念
8.1.1 定义与作用
Java注解(Annotation)是Java语言自JDK1.5版本引入的核心特性,其本质是为代码添加元数据的一个标记,通过@AnnotationName语法将元数据(Metadata)附加到代码元素(类、方法、字段等)上,用于描述或配置程序行为。
- 元数据特性:注解本身不直接影响业务逻辑,而是提供补充信息供编译器、框架或运行时环境使用。
- 非侵入式配置能力:注解通过元数据与代码解耦的特性,极大提升了代码可读性和框架扩展性,既支持编译器静态检查,也赋能框架动态行为控制。
8.1.2 典型应用场景
- 文档生成:如
@author、@param等注解配合Javadoc工具生成API文档。 - 框架集成:如Spring等框架通过
@Controller、@Service等注解实现依赖注入和配置简化。 - 数据校验:如JSR 303规范的
@NotNull、@Size等注解实现参数合法性校验。 - 代码生成:如Android的ButterKnife通过
@BindView生成视图绑定代码。 - 信息标记:为代码添加说明性标签,如标记方法重写(
@Override)或废弃方法(@Deprecated)。 - 运行时处理:通过反射(Reflection)读取注解信息,动态控制程序行为(如权限校验)。
8.2 注解的类型
8.2.1 按生命周期分类
-
SOURCE(源码级)
仅存在于源码中,编译后丢弃。常用于标记代码规范或生成辅助信息。
示例:@Override(检查方法重写)、@SuppressWarnings(抑制编译器警告)、Lombok的@Getter(触发编译时代码生成)。 -
CLASS(字节码级)
注解信息保留至.class文件,但运行时不可见。适用于编译后处理的工具(如AOP字节码增强)。
示例:AOP框架(如AspectJ)在类加载时修改字节码实现切面逻辑。 -
RUNTIME(运行时级)
注解信息在运行时可通过反射读取,是实现框架动态逻辑的核心。
示例:Spring的@Autowired(依赖注入)、JUnit的@Test(测试方法标识)。
8.2.2 按功能用途分类
-
元注解(Meta-Annotation)
用于定义其他注解的注解,包含以下核心类型:@Target:限定注解可标注的目标(例如ElementType.METHOD表示仅用于方法)。@Retention:指定注解生命周期(例如RetentionPolicy.RUNTIME)。@Inherited:允许子类继承父类注解。@Documented:将注解包含在Javadoc中。
-
内置注解(Built-in Annotations)
Java语言原生提供,主要用于编译检查或代码标记:- 编译校验:例如
@Override(验证方法重写)、@FunctionalInterface(标记函数式接口)。 - 代码标记:例如
@Deprecated(标识废弃方法)、@SuppressWarnings(忽略特定警告)。
- 编译校验:例如
-
自定义注解(Custom Annotations)
开发者根据需求定义的注解,需结合元注解配置作用范围。示例:
@Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface LogExecution { // 记录方法执行日志String level() default "INFO"; }
8.2.3 按来源定义分类
-
框架注解
主流框架定义的注解,用于简化配置和扩展功能。例如:- Spring:
@Controller(标记控制器)、@RequestMapping(定义HTTP接口路径)。 - JPA:
@Entity(标识实体类)、@Column(映射数据库字段)。
- Spring:
-
标准库注解
Java标准库中定义的通用注解。例如@SafeVarargs(抑制泛型可变参数警告)。
8.2.4 按处理阶段分类
-
编译时处理注解
通过APT(Annotation Processing Tool)在编译时生成代码或检查错误。
示例:Android的@BindView(生成视图绑定代码)、Lombok的@Data(自动生成Getter/Setter)。 -
运行时处理注解
依赖反射机制在运行时动态解析,实现业务逻辑。
示例:Spring的@Transactional(事务管理)、Hibernate的@Valid(参数校验)。
8.2.5 按作用域分类
-
类级别作用域
用于描述类的注解,通常放置在类定义的上面,可以用来指定类的一些属性,如类的访问级别、继承关系、注释等。 -
方法级别作用域
用于描述方法的注解,通常放置在方法定义的上面,可以用来指定方法的一些属性,如方法的访问级别、返回值类型、异常类型、注释等。 -
字段级别作用域
用于描述字段的注解,通常放置在字段定义的上面,可以用来指定字段的一些属性,如字段的访问级别、默认值、注释等。 -
其他作用域
除了这三种作用域,Java还提供了其他一些注解作用域,例如构造函数作用域和局部变量作用域。这些注解作用域可以用来对构造函数和局部变量进行描述和注释。
8.3 注解的运行机制
8.3.1 元数据定义规范
-
元数据本质
注解通过@interface关键字定义,本质上是一种继承java.lang.annotation.Annotation接口的特殊类型,所以注解也叫声明式接口。- 元注解控制:通过
@Target、@Retention等元注解限定作用目标(如方法、字段)和生命周期(SOURCE/CLASS/RUNTIME)。 - 元素定义:注解内部可声明方法(如
String value()),作为可配置参数。
- 元注解控制:通过
-
字节码存储
当注解被标记为 RUNTIME 时,Java 编译器会在生成的 .class 文件中保存注解信息。这些信息存储在字节码的属性表(Attribute Table)中,具体包括以下内容:RuntimeVisibleAnnotations:存储运行时可见的注解信息。RuntimeInvisibleAnnotations:存储运行时不可见的注解信息。RuntimeVisibleParameterAnnotations和RuntimeInvisibleParameterAnnotations:存储方法参数上的注解信息。
8.3.2 运行时解析机制
-
反射获取信息
Java提供AnnotatedElement接口(Class、Method等类实现)支持运行时获取注解:Method method = obj.getClass().getMethod("test"); Annotation[] annotations = method.getAnnotations(); // 获取所有注解- 底层原理:反射机制的核心类是
java.lang.reflect.AnnotatedElement,它是所有可以被注解修饰的元素(如Class、Method、Field等)的父接口。该接口提供了以下方法:getAnnotation(Class<T> annotationClass):获取指定类型的注解。getAnnotations():获取所有注解。isAnnotationPresent(Class<? extends Annotation> annotationClass):判断是否包含指定注解。
- 后端依赖: JVM 提供的本地方法
(Native Method),JVM 在加载类时会解析 .class 文件中的注解信息,并将其存储在内存中,供反射机制使用。 - 性能问题:频繁反射调用可能影响性能,框架常采用缓存或预解析优化(如Spring启动时扫描注解)。
- 底层原理:反射机制的核心类是
-
动态代理与容器管理
框架结合注解与代理模式实现功能扩展:- 事务管理:Spring对
@Transactional标注的方法生成代理,在调用前后管理事务。 - 权限校验:自定义
@RequireRole注解结合拦截器实现权限控制。
- 事务管理:Spring对
8.3.3 编译时处理机制
- APT(Annotation Processing Tool)
编译器调用注解处理器(继承AbstractProcessor)生成代码或报告错误:- 代码生成:如Android的ButterKnife通过
@BindView生成视图绑定代码、Lombok通过@Data修改AST(抽象语法树)在编译阶段生成Getter/Setter和toString()方法。 - 元编程:如MapStruct根据
@Mapper注解自动生成对象转换实现类。
- 代码生成:如Android的ButterKnife通过
8.3.4 框架集成范式
-
配置驱动模式
注解替代XML成为主流配置方式,实现高内聚低耦合:- Spring Boot:
@SpringBootApplication整合组件扫描、自动配置等能力。 - JPA/Hibernate:
@Entity定义实体类与数据库表的映射关系。
- Spring Boot:
-
声明式编程
通过注解声明意图而非编写具体逻辑:- 声明式事务:
@Transactional替代手动提交/回滚代码。 - 声明式缓存:
@Cacheable自动管理方法返回值缓存。
- 声明式事务:
本文由
CSDN用户Allen Wurlitzer原创,遵循CC-BY-SA协议发布,转载请注明出处。
相关文章:
Java基础知识总结(1.8)——Java 注解(持续更新)
更新时间:2025-03-31 Web后端专栏:CSDN专栏——理论-Web后端技术博客总目录:计算机技术系列博客——目录页 8.1 注解的概念 8.1.1 定义与作用 Java注解(Annotation)是Java语言自JDK1.5版本引入的核心特性࿰…...
【Yolov8部署】 VS2019+opencv+onnxruntime 环境下部署目标检测模型
文章目录 前言一、导出yolov8模型为onnx文件二、VS2019中环境配置三、源码与实际运行 前言 本文主要研究场景为工业场景下,在工控机与工业相机环境中运行的视觉缺陷检测系统,因此本文主要目的为实现c环境下,将yolov8已训练好的检测模型使用o…...
论文阅读:Dual Anchor Graph Fuzzy Clustering for Multiview Data
论文地址:Dual Anchor Graph Fuzzy Clustering for Multiview Data | IEEE Journals & Magazine | IEEE Xplore 代码地址:https://github.com/BBKing49/DAG_FC 摘要 多视角锚图聚类近年来成为一个重要的研究领域,催生了多个高效的方法。然而&#…...
Lambda 表达式是什么以及如何使用
目录 📌 Kotlin 的 Lambda 表达式详解 🎯 什么是 Lambda 表达式? 🔥 1. Lambda 表达式的基本语法 ✅ 示例 1:Lambda 基本写法 ✅ 示例 2:使用 it 关键字(单参数简化) ✅ 示例 3…...
乐橙R10 AI智能锁:以「技术减法」终结智能家居「参数内卷」
1 行业迷思:当「技术内卷」背离用户真实需求 “三摄猫眼”、“0.3秒人脸解锁”、“DeepSeek大模型”……智能锁行业的营销话术日益浮夸,但用户体验却陷入“功能冗余”与“操作复杂”的泥潭。 一位用户在社交平台直言:“我的智能锁有六个摄像…...
如何使用 FastAPI 构建 MCP 服务器
哎呀,各位算法界的小伙伴们!今天咱们要聊聊一个超酷的话题——MCP 协议!你可能已经听说了,Anthropic 推出了这个新玩意儿,目的是让 AI 代理和你的应用程序之间的对话变得更顺畅、更清晰。不过别担心,为你的…...
基于Python的Django框架的手机购物商城管理系统
标题:基于Python的Django框架的手机购物商城管理系统 内容:1.摘要 随着互联网的快速发展,手机购物逐渐成为人们日常生活中不可或缺的一部分。本研究的目的是开发一个基于Python的Django框架的手机购物商城管理系统,以提高购物商城的管理效率和用户体验。…...
【UE5.3.2】初学1:适合初学者的入门路线图和建议
3D人物的动作制作 大神分析:3D人物的动作制作通常可以分为以下几个步骤: 角色绑定(Rigging):将3D人物模型绑定到一个骨骼结构上,使得模型能够进行动画控制。 动画制作(Animation):通过控制骨骼结构,制作出人物的各种动作,例如走路、跳跃、打斗等。 动画编辑(Ani…...
当 EcuBus-Pro + UTA0401 遇上 NSUC1500
文章目录 1.前言2.EcuBus-Pro简介2.1 官方地址2.2 概览 3.纳芯微NSUC1500简介3.1 NSUC1500概述3.2 产品特性 4.测试环境5.基础功能5.1 数据发送5.2 数据监控 6.自动化功能6.1 脚本创建6.2 脚本编辑6.3 脚本编辑与测试 7.音乐律动7.1 导入例程7.2 效果展示 ECB工程 1.前言 最近…...
qml 中的anchors
理解 QML 中的 anchors(锚定) 在 QML 中,anchors 是一种强大的布局机制,用于相对于父元素或同级元素定位和调整组件大小。它比简单的 x/y 坐标定位更灵活,能够自动适应不同屏幕尺寸。 基本概念 在你的代码中&#x…...
【FreeRTOS】裸机开发与操作系统区别
🔎【博主简介】🔎 🏅CSDN博客专家 🏅2021年博客之星物联网与嵌入式开发TOP5 🏅2022年博客之星物联网与嵌入式开发TOP4 🏅2021年2022年C站百大博主 🏅华为云开发…...
Deepseek API+Python 测试用例一键生成与导出 V1.0.4 (接口文档生成接口测试用例保姆级教程)
接口文档生成接口测试用例保姆级教程 随着测试需求的复杂性增加,测试用例的设计和生成变得愈发重要。Deepseek API+Python 测试用例生成工具在 V1.0.4 中进行了全方位的优化和功能扩展,特别是对接口测试用例设计的支持和接口文档的智能解析处理。本文将详细介绍 V1.0.4 版本…...
CET-4增量表
CET-4词表-增量表 注: 【1】所谓增量,是相对于高中高考之增量 即,如果你是在读大学生,高中英语单词过关了,准备考CET-4,那么侧重下面的增量词表的学习,也算是一条捷径吧 ^_^ 【2】本结果数据 官…...
DeepSeek详解:探索下一代语言模型
文章目录 前言一、什么是DeepSeek二、DeepSeek核心技术2.1 Transformer架构2.1.1 自注意力机制 (Self-Attention Mechanism)(a) 核心思想(b) 计算过程(c) 代码实现 2.1.2 多头注意力 (Multi-Head Attention)(a) 核心思想(b) 工作原理(c) 数学描述(d) 代码实现 2.1.3 位置编码 (…...
深入解析主线程退出与子线程管理:何时 Join(),何时 Detach()?
在多线程编程中,主线程退出时如何正确管理子线程是一个关键问题。如果子线程没有 Join() 或 Detach(),不同的操作系统会有不同的行为,可能导致内存泄漏、资源竞争、甚至程序崩溃。本文将深入探讨主线程退出时子线程的管理策略,并提…...
AWS API Gateway Canary部署实战:Lambda到ECS的平滑迁移指南
在云原生架构中,如何实现服务平滑迁移是一个常见挑战。本文将详细介绍如何利用AWS API Gateway的Canary部署功能,实现从Lambda函数到ECS服务的无缝迁移,同时保证客户端无感知并提供便捷的回退机制。 一、迁移方案概述 在本方案中,我们将实现以下目标: 将现有Lambda服务平…...
Docker学习--容器操作相关命令--docker export 命令
docker export 命令的作用: 用于将 Docker 容器的文件系统导出为一个 tar 归档文件。主要用于备份或迁移容器的文件系统,而不包括 Docker 镜像的所有层和元数据。 语法: docker export [参数选项] CONTAINER(要操作的容器&#x…...
【Easylive】获取request对象的两种方式
【Easylive】项目常见问题解答(自用&持续更新中…) 汇总版 1. 通过方法参数直接注入(Spring MVC 推荐) 在 Controller 方法中直接声明 HttpServletRequest 参数,Spring 会自动注入当前请求的 request 对象&#…...
FOC 控制笔记【三】磁链观测器
一、磁链观测器基础 1.1 什么是磁链 磁链(magnetic linkage)是电磁学中的一个重要概念,指导电线圈或电流回路所链环的磁通量。单位为韦伯(Wb),又称磁通匝。 公式为: 线圈匝数 穿过单匝数的…...
SpringBoot项目读取自定义的配置文件
先说使用场景: 开发时在resource目录下新建一个 config 文件夹, 在里面存放 myconf.properties 文件, 打包后这个文件会放到与jar包同级的目录下, 如下图 关键点:自定义的文件名(当然后缀是.properties),自定义的存放路径。 主要的要求是在打包后运行过…...
UniApp快速表单组件
环境:vue3 uni-app 依赖库:uview-plus、dayjs 通过配置项快速构建 form 表单 使用 <script setup>import CustomCard from /components/custom-card.vue;import { ref } from vue;import CustomFormItem from /components/form/custom-form-it…...
在PyCharm 中免费集成Amazon CodeWhisperer
CodeWhisperer 是Amazon发布的一款免费的AI 编程辅助小工具,可在你的集成开发环境(IDE)中生成实时单行或全函数代码建议,帮助你快速构建软件。简单来说,Amazon CodeWhisperer就是你写一段注释(支持中文&…...
语音克隆(Voice Cloning)
要将文字转化为“自己声音”的音频,需要用到语音克隆(Voice Cloning)技术。这种技术通常要求用户提供一定量的语音样本(几分钟到几小时不等),然后通过 AI 模型生成与你声音相似的音频。目前市面上完全免费且…...
[7-02-02].第15节:生产经验 - 消费者相关操作
Kafka笔记大纲 五、生产经验——分区的分配以及再平衡: 4.1.生产经验——分区的分配以及再平衡 4.2.参数: 5.4.1 Range 以及再平衡...
Matlab_Simulink中导入CSV数据与仿真实现方法
前言 在Simulink仿真中,常需将外部数据(如CSV文件或MATLAB工作空间变量)作为输入信号驱动模型。本文介绍如何高效导入CSV数据至MATLAB工作空间,并通过From Workspace模块实现数据到Simulink的精确传输,适用于运动控制…...
vue3大屏适配
最近写大屏,发现适配真的好难统一,不是这有问题就是那有问题,要不然页面拉伸的就变形了,在网上找到了一个好用的插件,暂时用起来没问题,如果后续有问题或者大家有什么好的想法可以在评论区说一下。 插件 bi…...
文件操作与IO—File类
目录 1 属性 2 构造方法 3 常用方法 4 示例代码 1 属性 修饰符与类型 属性 含义 static String pathSeparator 依赖于系统的路径分隔符,String类型的表示 static char pathSeparator 依赖于系统的路径分隔符,char类型的表示 2 构造方法 构造…...
音频进阶学习二十四——IIR滤波器设计方法
文章目录 前言一、滤波器设计要求1.选频滤波器种类2.通带、阻带、过度带3.滤波器设计指标 二、IIR滤波器的设计过程1.设计方法2.常见的模拟滤波器设计1)巴特沃斯滤波器(Butterworth Filter)2)切比雪夫滤波器(Chebyshev…...
OpenBMC:BmcWeb 处理http请求2 查找路由对象
OpenBMC:BmcWeb 处理http请求1 生成Request和AsyncResp对象_bmc web-CSDN博客 当接收到http请求,并且完成解析后,调用了App::handle处理请求 而App::handle又调用了router.handle(req, asyncResp);来处理请求 1.Router::handle void handle(const std::shared_ptr<Requ…...
MVC编程
MVC基本概述 例子——显示本地文件系统结构 先分别拖入ListView,TableView,TreeView 然后在进行布局 在widget.cpp 结果 mock测试 1,先加入json测试对象 2.创建后端目录 3,在src添加新文件 在models文件夹里 在mybucket.h,添加测试用例的三个字段 4.在…...
