03. 《Lombok 实战 —— @toString & @EqualsAndHashCode》

本文详细介绍了Lombok库中的@toString和@EqualsAndHashCode两个注解的使用,从入门到深度研究,包括全局配置。@toString用于自动生成toString方法,@EqualsAndHashCode则用于简化equals和hashCode方法的实现。文章通过源码分析和示例代码展示了如何进行个性化配置,如排除字段、显示字段名、排序等。
摘要由CSDN通过智能技术生成

《Lombok 实战 —— @toString & @EqualsAndHashCode》

1. @toString

No need to start a debugger to see your fields: Just let lombok generate a toString for you!

1.1 入门使用@toString

任何类定义都可以用@ToString注释,让lombok生成toString()方法的实现。 默认情况下,它会按顺序打印类名和每个字段,并以逗号分隔,如下所示:

@Getter
@Setter
@ToString
public class User {
   
    private String username;
    private String password;
    private boolean isAdult;
}

// 编译后:
public class User {
   
    private String username;
    private String password;
    private boolean isAdult;
	// 其他省略
    public String toString() {
   
        return "User(username=" + this.getUsername() + 
        ", password=" + this.getPassword() + 
        ", isAdult=" + this.isAdult() + ")";
    }
}

在编译后地结果中可以看到,lombok默认使用的是getter方法进行设值,如this.getUsername(),但是我们实际并不需要通过getter的方式进行设置,lombok也知道我们有这样的需求,为我们提供了注解配置项,下面我们就来继续看看如何进行更个性化的配置@toString

1.2 深度研究@toString

深度研究一个东西,肯定少不了源码的分析,当然@toString的代码并不难,放一百个心,如下所示:

@Target(ElementType.TYPE)
@Retention(RetentionPolicy.SOURCE)
public @interface ToString {
   
	// 输出是否带字段名称
	boolean includeFieldNames() default true;
	// 排除字段,以 String[] 格式设置
	String[] exclude() default {
   };
	// 指定输出哪些字段,不过将来会被标注@deprecated,使用 @ToString.Include 替代
	String[] of() default {
   };
	// 是否调用父类的 toString() 方法
	boolean callSuper() default false;
	// 不使用 getter 方法获取字段值
	boolean doNotUseGetters() default false;
	// 是否只输出被 @ToString.Include 备注的属性,默认情况输出所有非静态字段
	boolean onlyExplicitlyIncluded() default false;
	
	// 标注不被输出的字段
	@Target(ElementType.FIELD)
	@Retention(RetentionPolicy.SOURCE)
	public @interface Exclude {
   }
	
	// 标注被输出的字段 @ToString.Include
	@Target({
   ElementType.FIELD, ElementType.METHOD})
	@Retention(RetentionPolicy.SOURCE)
	
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
`@EqualsAndHashCode` 是 Lombok 提供的一个注解,用于生成类的 equals() 和 hashCode() 方法,这在处理集合操作和数据库查询时尤其有用。它会检查类中哪些字段是对象标识的一部分(如主键),并据此计算 `equals()` 和 `hashCode()` 的返回值。 当在类上使用 `@EqualsAndHashCode` 注解时,Lombok 将自动添加对对象自身和其他类实例的引用作为比较的对象部分。默认情况下,这个方法会调用 super 类(如果存在的话)的 equals() 和 hashCode() 方法。 然而,在某些情况下,我们可能希望禁止从超类继承的 equals() 和 hashCode() 行为,而是仅基于类当前的状态进行比较。这就是 `callSuper = false` 这个属性派上了用场。当我们向 `@EqualsAndHashCode` 添加 `callSuper = false` 参数时,那么类将不再调用超类的 `equals()` 和 `hashCode()` 方法。 例如: ```java import lombok.EqualsAndHashCode; @EqualsAndHashCode(callSuper = false) public class MyCustomClass extends SomeBaseClass { // ... // 自定义 equals() 和 hashCode() 根据当前对象状态 } ``` 通过使用 `callSuper = false` 属性,我们可以确保 `MyCustomClass` 实现了自己的逻辑来进行比较,而不会受到其超类行为的影响。这种做法通常适用于那些想要根据自定义规则实现比较逻辑的情况,而不是仅仅依赖于基础类型的数据。 --- ### 相关问题: 1. 在什么情况下应该禁用 `@EqualsAndHashCode.callSuper`? 2. `@EqualsAndHashCode` 注解与其他注解(如 `@ToString`, `@Getter`, `@Setter` 等)一起使用时有何区别? 3. 如何使用 `@EqualsAndHashCode` 为某个字段提供特定的排除机制,使其不影响 `equals()` 和 `hashCode()` 的生成?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

「已注销」

滚蛋吧,结核菌!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值