1. Lombok 簡介
Lombok 可以通過簡單的注解來幫助我們簡化消除一些必須有但顯得很臃腫的Java代碼,通過使用對應的注解,可以在編譯源碼的時候生成對應的方法。
Lombok 既是一個 IDE 插件,也是一個項目要依賴的 jar 包。
Lombok 依賴 jar 包的原因是因為編譯時要用它的注解。插件的原因是他要在編譯器編譯時通過操作 AST (抽象語法樹)改變字節碼生成。
也就是說它可以改變 Java 語法. 它不像 Spring 的依賴注入或者 Hibernate 的 orm 一樣是運行時的特性,而是編譯時的特性。
官網地址:https://projectlombok.org
2. 使用方式
Maven 坐標:
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>${lombok.version}</version>
</dependency>
IDEA 安裝插件:
編譯時啟用注解處理:
3. 項目實戰
不使用 Lombok @Data:
public class Student{ private int age = 10; private String name; public int getAge() { return age; } public void setAge(int age) { this.age = age; } protected void setName(String name) { this.name = name; } }
使用 Lombok @Data (編譯時為所有字段添加@ToString/@EqualsAndHashCode/@Getter/為非final字段添加@Setter/@RequiredArgsConstructor):
@Data public class Student{ private int age = 10; private String name; }
不使用 Lombok @CleanUp:
InputStream in = new FileInputStream(args[0]); try { OutputStream out = new FileOutputStream(args[1]); try { byte[] b = new byte[10000]; while (true) { int r = in.read(b); if (r == -1) { break; } out.write(b, 0, r); } } finally { if (out != null) { out.close(); } } } finally { if (in != null) { in.close(); } }
使用 Lombok@CleanUp(在編譯時添加調用close方法):
@Cleanup InputStream inputStream = new FileInputStream(args[0]); @Cleanup OutputStream outputStream = new FileOutputStream(args[1]); byte[] b = new byte[10000]; while (true) { int r = inputStream.read(b); if (r == -1) break; outputStream.write(b, 0, r); }
當然還有比 @Data 粒度更小的注解,比如 @Getter、@Setter、@NoArgsConstructor,更多注解:https://projectlombok.org/features/all