lombok常用注解使用与原理

2024-06-21 14:52

本文主要是介绍lombok常用注解使用与原理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

什么是lombok

  • 一个优秀的Java代码库,简化了Java的编码,为Java代码的精简提供了一种方式

使用方法:pom文件中引入依赖

<!--scope:provided,只在编译阶段生效,不需要打入包中-->
<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.16</version><scope>provided</scope>
</dependency>

@Getter/@Setter

  • 作用类上,生成所有成员变量的set/get方法

  • 作用于成员变量上,生成该成员变量的set/get方法

  • 方法控制访问级别@Getter/@Setter注解加上AccessLevel:PUBLIC, MODULE, PROTECTED, PACKAGE, PRIVATE,NONE(不生成);示例:@Getter(AccessLevel.PRIVATE)

  • final修饰只会生成get方法

  • static修饰不会生成set/get方法

@NonNull

  • 作用于方法上或者属性,用于非空判断,如果为空则抛异常

  • 代码

    public void test(@NonNull String name) {System.out.println(name);
    }
    
  • 字节码

    public void test(@NonNull String name) {if (name == null) {throw new NullPointerException("name is marked non-null but is null");} else {System.out.println(name);}
    }
    

构造器注解

  • @NoArgsConstructor无参构造器

  • @AllArgsConstructor全参构造器

  • @RequiredArgsConstructor

    • 指定参数的构造函数,有以下特征的字段:final类型未被初始化的属性,标记了@NonNull的属性

@ToString

  • 作用于类,覆盖默认的toString()方法
  • 不包括某个字段@ToString(exclude = {"createTime"})
  • 只输出某个字段@ToString(of = {"createTime"})

@EqualsAndHashCode

  • 作用于类,覆盖默认的equals和hashCode方法,作用于全部字段
  • 不包括某个字段@EqualsAndHashCode(exclude = {"createTime"})
  • 只输出某个字段@EqualsAndHashCode(of = {"createTime"})

@Data

  • 作用于类上,是以下注解的集合
    • Getter
    • Setter
    • RequiredArgsConstructor
    • ToString
    • EqualsAndHashCode

@Builder

  • 构造者模式:又称之为建造者模式
    • 场景:当一个bean类重载了多个构造方法时,并且参数随机使用时,考虑使用构造者模式
    • 谷歌的开源protobuf协议生产的java bean赋值就是采用建造者模式
  • @Builder作用于类上
  • 使用:User user = User.builder().id(1).build();

@Log/@Sl4j

  • 作用于类上,生成日志变量,用于记录日志

  • 使用:log.info("info日志");

使用注意点

如果只使用了@Data,而不使用@EqualsAndHashCode(callSuper = true)的话,会默认@EqualsAndHashCode(callSuper = false),这时候生成的equals()方法只会比较子类的属性,不会考虑从父类继承的属性,无论父类属性访问权限是否开放

lombok实现原理

  • 熟悉Java自定义注解的同学已经猜到是JSR269插件化注解处理

  • JSR269:Pluggable Annotation Processing API实现在Javac编译阶段利用“Annotation Processor“对自定义的注解进行预处理后生成真正在JVM上面执行的Class文件

  • JSR是Java Specification Requests的缩写,意思是Java规范提案。是指向JCP(Java Community Process)提出新增一个标准化技术规范的正式请求。任何人都可以提交JSR,以向Java平台增添新的API和服务。JSR已成为Java界的一个重要标准

  • lombok解析流程如下

    Javac解析成AST抽象语法树后,lombok根据自己编写的注解处理器,动态的修改AST增加新的节点(即lombok自定义注解所需要生成的代码),最终生成JVM可执行的字节码Class文件

  • 能实现上述效果的还有一个反射技术,那两个对比如何?

    • 使用Annotation Processing自定义注解是在编译阶段进行修改
    • JDK反射技术是在运行时动态修改
    • 结论:反射更加灵活但是带来的性能损耗更加大

这篇关于lombok常用注解使用与原理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1081524

相关文章

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

python常用的正则表达式及作用

《python常用的正则表达式及作用》正则表达式是处理字符串的强大工具,Python通过re模块提供正则表达式支持,本文给大家介绍python常用的正则表达式及作用详解,感兴趣的朋友跟随小编一起看看吧... 目录python常用正则表达式及作用基本匹配模式常用正则表达式示例常用量词边界匹配分组和捕获常用re

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

ModelMapper基本使用和常见场景示例详解

《ModelMapper基本使用和常见场景示例详解》ModelMapper是Java对象映射库,支持自动映射、自定义规则、集合转换及高级配置(如匹配策略、转换器),可集成SpringBoot,减少样板... 目录1. 添加依赖2. 基本用法示例:简单对象映射3. 自定义映射规则4. 集合映射5. 高级配置匹

MySQL中的表连接原理分析

《MySQL中的表连接原理分析》:本文主要介绍MySQL中的表连接原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、表连接原理【1】驱动表和被驱动表【2】内连接【3】外连接【4编程】嵌套循环连接【5】join buffer4、总结1、背景

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

使用Python绘制3D堆叠条形图全解析

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下... 目录为什么选择 3D 堆叠条形图代码实现:从数据到 3D 世界的搭建核心代码逐行解析细节优化应用场景:3D 堆叠图

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左