先在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);//我滴妈,这样直接赋值的,出来的也只是地址,只能是一个个的把属性说出来,才能输出
}