@Data 、@AllArgsConstructor 、@NoArgsConstructor、

先在maven添加好依赖,引入lombok,引入这个工具,是用来简化自己的代码书写的,看起来简洁一些

<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.18.4</version>
    <scope>provided</scope>
</dependency>

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

缺点:
不支持多种参数构造器的重载,比如从属性里面随遍挑出来几个,如果需要用到的话,自己手动书写。
虽然省去了手动创建getter/setter方法的麻烦,但大大降低了源代码的可读性和完整性,降低了阅读源代码的舒适度
像 lombok 这种插件,已经不仅仅是插件了,它在编译器编译时通过操作AST(抽象语法树)改变字节码生成,变相的说它就是在改变java语法,它改变了你编写源码的方式,它不像 spring 的依赖注入一样是运行时的特性,而是编译时的特性。如果一个项目有非常多这样的插件,会极大的降低阅读源代码的舒适度。

 

接下来是代码对比:

这是没有使用lombok里面的各种注解的

public class Teacher {
    private Integer id;
    private String name;
    private Integer age;
    private char gender;//记得字符要用单引号''


//   @NoArgsConstructor //无参构造方法
    public Teacher() {}


    //可以使用@AllArgsConstructor //全部参数的构造方法
    public Teacher(Integer id, String name, Integer age, char gender) {
        this.id = id;
        this.name = name;
        this.age = age;
        this.gender = gender;
    }

    //底下的get和set方法,可以使用@Data,
    //set就是把你写的数据放进这个类里面,然后set是把这个类里面的数据给你取出来
    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public char getGender() {
        return gender;
    }

    public void setGender(char gender) {
        this.gender = gender;
    }

    @Override
    public String toString() {
        return "Teacher{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", age=" + age +
                ", gender=" + gender +
                '}';
    }
}

接下来写那些使用@的

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Teacher {
    private Integer id;
    private String name;
    private Integer age;
    private char gender;//记得字符要用单引号''

    @Override
    public String toString() {
        return "Teacher{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", age=" + age +
                ", gender=" + gender +
                '}';
    }
}

这样一看,可以少些很多东西

我们来测试一下来

@Test
    public void TeacherTest(){

        Teacher teacher = new Teacher(1,"张三",23,'a');

        System.out.println("teacher = "+teacher);
        System.out.println(teacher.getId());//通过@Data里面的get方法拿到这个teacher的Id
        System.out.println(teacher.getName());
        System.out.println(teacher.getAge());
        System.out.println(teacher.getGender());

        System.out.println(teacher.getClass());//这个类名.getClass()是通过类的名字来得到类,是不包含在@Data里面的

        Teacher casually = new Teacher();
        casually.setId(1);//类已经建好了,叫casually,然后现在使用set函数往里面放数据吧
        casually.setName("王二麻子");
        casually.setAge(23);
        casually.setGender('a');

        System.out.println("casually = "+casually);
        System.out.println("casually 的类是 " +casually.getClass());
    }

我们这里再来说一下set方法,前面我们写的类里面的各个属性都是私有private的,所以我们需要使用set方法把数据放进去,那么假如有个类他里面的属性都是共有的呢?我们来试试

先写类

import lombok.AllArgsConstructor;
import lombok.NoArgsConstructor;

//@Data
@AllArgsConstructor
@NoArgsConstructor
public class PublicTeacher {
    public Integer id;
    public String name;
    public Integer age;

}

再写测试

@Test
    public void PublicTeacher(){
        PublicTeacher teacher01 = new PublicTeacher();
        teacher01.id = 12;//这里不需要set方法了,直接可以赋值
        teacher01.name = "王五";
        teacher01.age = 34;

        System.out.println(teacher01.id);
        System.out.println(teacher01.name);
        System.out.println(teacher01.age);
        System.out.println(teacher01.getClass());
        System.out.println(teacher01);//这里的结果是个地址,无法输出这个东西里面的全部数据
        //看来是公共属性的话,放进去属性之后,那么无法一下子全部拿出来

        PublicTeacher teacher02 = new PublicTeacher(1,"大大大",12);
        System.out.println(teacher02);//我滴妈,这样直接赋值的,出来的也只是地址,只能是一个个的把属性说出来,才能输出

    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用中提到了@Data、@NoArgsConstructor和@AllArgsConstructor这三个注解。这些注解是由Lombok提供的。要使用这些注解,需要在项目的依赖中添加Lombok的相关依赖。具体来说,需要添加以下依赖 - Maven: ``` <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.20</version> <scope>provided</scope> </dependency> ``` - Gradle: ``` compileOnly 'org.projectlombok:lombok:1.18.20' annotationProcessor 'org.projectlombok:lombok:1.18.20' ``` 这样就可以在项目中使用@Data、@NoArgsConstructor和@AllArgsConstructor注解了。它们将自动生成相应的方法和构造函数,减少了开发过程中的样板代码。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [实体层@Data @AllArgsConstructor @NoArgsConstructor的注解的使用实体层@Data @AllArgsConstructor @...](https://blog.csdn.net/weixin_44495029/article/details/111914795)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [SpringBoot框架中,经常使用的注解:@Data、@AllArgsConstructor、@NoArgsConstructor,这三个注解的详细...](https://blog.csdn.net/vipzyj/article/details/130080088)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值