这是一个比较奇特的插件。基于注解,使我们的代码更简洁,帮助我们生成一些getter,setter或者tostring之类的代码。
使用方式:
1.引入maven:
<dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.16.10</version> </dependency>这个maven的依赖为我们提供了注解的api。
常见的注解:
@Data,类级别注解,为我们生成getter,setter,toString方法。
@AllArgsConstructor,@NoArgsConstructor,类级别注解,生成全参和无参的构造方法。
@Getter,@Setter,属性级别的注解,生成getter和setter方法。
import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; @AllArgsConstructor @NoArgsConstructor @Data public class Bean { String name; int id; }
这样就是用lombok的注解构建了一个java bean的类。但是,如果我们使用ide,还需要导插件。
2.这与lombok的原理有关,lombok是在编译class文件的时候,通过修改语法树来实现添加代码的。所以我们在ide里写好类,并且想在其他类中想要调用这个bean的方法,由于此时还没有编译,那么lombok就无法为我们生成辅助代码,ide也就无法找到这些方法。要想让ide识别出这些方法,就需要为ide导入相关的插件,我用的idea,只需要在settings>pulgin下的资源库搜索lombok,安装再重启,ide就可以识别lombok的注解了。
导入之后,就可以在api中看到之前注解生成的方法了:
public class App { public static void main( String[] args ) { Bean bean = new Bean(); bean.getId(); new Bean("ly", 1); } }其实这个插件使用起来还是挺简单的。后来研究了下它是如何生成code的,发现jar文件里全是.lombok的文件,实现还是比较晦涩的,看了一些网站,了解到它是基于java编译器实现的,也就是在编译时修改了抽象语法树从而添加代码的。由于eclipse自己实现了一个编译器,所以它分成了eclipse版本和javac版本。貌似我们可以自定义需求,生成自己的代码。关于实现没有做太多的研究。