前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Lombok插件的安装以及使用

Lombok插件的安装以及使用

作者头像
Devops海洋的渔夫
发布2021-01-07 09:48:30
6610
发布2021-01-07 09:48:30
举报
文章被收录于专栏:Devops专栏Devops专栏Devops专栏

12. Lombok插件的安装以及使用

LomboK介绍和配置(能用就用如果使用出问题就不要用)

1.目标

  • 掌握LomboK的配置

2.路径

  1. 什么是LomboK
  2. LomboK的作用
  3. LomboK的配置

3.讲解

3.1什么是LomboK

Lombok是一个Java库,能自动插入编辑器并构建工具,简化Java开发。

官网: https://www.projectlombok.org/

3.2Lombok的作用

通过添加注解的方式,Lombok能以简单的注解形式来简化java代码,提高开发人员的开发效率。

例如开发中经常需要写的javabean,都需要花时间去添加相应的getter/setter,也许还要去写构造器、equals等方法,而且需要维护,当属性多时会出现大量的getter/setter方法,这些显得很冗长也没有太多技术含量,一旦修改属性,就容易出现忘记修改对应方法的失误。

而使用 Lombok 插件后,就不需要在代码里面写getter/setter/toString/HashCode等等方法,将会在编译后的class文件中自动添加,使代码看起来更简洁些。

3.3 Lombok的配置
3.3.1 添加maven依赖
<dependency>
 <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
 <version>1.18.8</version>
 <scope>provided</scope>
</dependency>
3.3.2 安装插件

使用Lombok还需要插件的配合,我使用开发工具为idea. 打开idea的设置,点击Plugins,点击Browse repositories,在弹出的窗口中搜索lombok,然后安装即可.

另外,新版本的安装界面如下:

安装完了插件之后,基本就完成了。

可以开启服务,测试能否正常启动编译如下:

不过也有些时候会碰到编译时出错的情况,可以按照下面进行解决。

3.3.3 解决编译时出错问题

编译时出错,可能是没有enable注解处理器。Annotation Processors > Enable annotation processing。设置完成之后程序正常运行。

4.小结

  1. Lombox: 就是一个工具, 简化java代码开发
  2. Lombok环境
    • 添加坐标
    • 添加插件

Lombok的常用注解

1.目标

  • 掌握Lombox的常用注解

2.路径

  1. @Data
  2. @Getter/@Setter
  3. @ToString
  4. @NoArgsConstructor, @AllArgsConstructor

3.讲解

3.1@Data

@Data注解在类上,会为类的所有属性自动生成setter/getter、equals、canEqual、hashCode、toString方法,如为final属性,则不会为该属性生成setter方法。

3.1.1 在项目中创建 JavaBean,创建一个User类,并使用 @Data 注解
package com.bean;

import lombok.Data;

/**
 *
 * Data注解:
 * 可以添加get、set、toString、equals、hashcode等等方法
 * 
 * @author Aron.li
 * @date 2020/12/14 0:19
 */
@Data
public class User {
    private Integer id;
    private String username;
    private String password;
    private String address;
    private String nickname;
    private String gender;
    private String email;
    private String status;
}
3.1.2 创建一个单元测试,测试能否执行 get、set、toString、equals、hashcode等等方法
public class UserTest {

    @Test
    public void test01(){
        User user = new User();
        user.setUsername("肥子白");
        user.setNickname("fat boy");
        user.setEmail("381789@qq.com");

        System.out.println(user.getUsername());
        System.out.println(user);
    }

}
3.1.3 查看编译后生成的 class 文件,可以看到 Lombok 自动生成的代码

如果想要确认自动生成了什么,可以看编译后的 class 文件更加直观。

3.2@Getter/@Setter

如果觉得@Data太过粗暴不够精细,可以使用@Getter/@Setter注解,此注解在属性上,可以为相应的属性自动生成Getter/Setter方法.

3.2.1 针对某个属性进行 @Getter/@Setter注解
public class User implements Serializable {
    @Setter
    @Getter
    private Integer id;
    private String username;
    private String password;
    private String address;
    private String nickname;
    private String gender;
    private String email;
    private String status;
}
3.2.2 查看再次执行编译后的 class 文件

可以看到只生成了空参构造器,以及 id 的 getter/setter

3.3@ToString

类使用@ToString注解,Lombok会生成一个toString()方法,默认情况下,会输出类名、所有属性(会按照属性定义顺序),用逗号来分割。通过exclude属性指定忽略字段不输出,

3.3.1 @ToString 使用 exclude 指定忽略 id 字段不输出
@ToString(exclude = {"id"})
public class User implements Serializable {
    private Integer id;
    private String username;
    private String password;
    private String address;
    private String nickname;
    private String gender;
    private String email;
    private String status;
}
3.3.2 查看再次执行编译后的 class 文件
3.4@xxxConstructor
  • @NoArgsConstructor: 无参构造器
@NoArgsConstructor
public class User implements Serializable{
    private Integer id;
    private String username;
    private String password;
    private String address;
    private String nickname;
    private String gender;
    private String email;
    private String status;
}
  • @AllArgsConstructor: 全参构造器
@AllArgsConstructor
public class User implements Serializable{
    private Integer id;
    private String username;
    private String password;
    private String address;
    private String nickname;
    private String gender;
    private String email;
    private String status;
}
3.4.1 设置自动生成 无参构造器 以及 全参构造器
@AllArgsConstructor
@NoArgsConstructor
@ToString(exclude = {"id"})
public class User implements Serializable {
    private Integer id;
    private String username;
    private String password;
    private String address;
    private String nickname;
    private String gender;
    private String email;
    private String status;
}
3.4.2 查看再次执行编译后的 class 文件

4.小结

4.1注解
  • @Data
    • 用在类上面的 , 生成set,get, toString, hashCode,canEqual、toString方法
  • @Getter
  • 用在字段, 生成get方法
  • @Setter
    • 用在字段, 生成set方法
  • @ToString
    • 用在类上面的 生成toString方法
  • @xxxConstructor
    • 用在类上面的 生成构造方法 (只能生成无参和全参的构造方法)
4.2优缺点

优点:

  1. 能通过注解的形式自动生成构造器、getter/setter、equals、hashcode、toString等方法,提高了一定的开发效率
  2. 让代码变得简洁,不用过多的去关注相应的方法
  3. 属性做修改时,也简化了维护为这些属性所生成的getter/setter方法等

缺点:

  1. 不支持多种参数构造器的重载
  2. 由于环境问题可能会导致lombok失效,如果遇到这种情况,直接不要使用lombok
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-12-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 海洋的渔夫 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 12. Lombok插件的安装以及使用
    • LomboK介绍和配置(能用就用如果使用出问题就不要用)
      • 1.目标
      • 2.路径
      • 3.讲解
      • 4.小结
    • Lombok的常用注解
      • 1.目标
      • 2.路径
      • 3.讲解
      • 4.小结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档