首頁(yè)技術(shù)文章正文

Java-Lombok 的使用

更新時(shí)間:2018-09-12 來(lái)源:黑馬程序員JavaEE培訓(xùn)學(xué)院 瀏覽量:

    

Java-Lombok 的使用

 

前言

Lombok 是一種 Java? 實(shí)用工具,可用來(lái)幫助開發(fā)人員消除 Java 的冗長(zhǎng),尤其是對(duì)于簡(jiǎn)單的 Java 對(duì)象(POJO)。它通過注解實(shí)現(xiàn)這一目的。

正文添加依賴在 pom.xml 文件中添加相關(guān)依賴:

<lombok.version>1.16.20</lombok.version

<dependency>

<groupId>org.projectlombok</groupId>            

<artifactId>lombok</artifactId>            

<version>${lombok.version}</version>           

<scope>provided</scope>       

</dependency>

安裝插件由于 Lombok 采取的注解形式的,在編譯后,自動(dòng)生成相應(yīng)的方法,為了不讓 ide 瘋了,需要下載插件了支持它。

以 idea 為例:查找插件 lombok plugin 安裝即可。

用我的 User 實(shí)體類為例(set,get,toString 方法),

@Getter@Setter@ToStringpublic class SysUserEntity implements Serializable在按快捷鍵 Ctrl + F12,可以查找到set,get,toString 方法。

注解寫點(diǎn)常用的,其余的 api 的打開 Jar 包一目了然

@Getter@Setter@ToString@EqualsAndHashCode構(gòu)造函數(shù)@AllArgsConstructor會(huì)生成一個(gè)包含所有變量,同時(shí)如果變量使用了NotNull annotation , 會(huì)進(jìn)行是否為空的校驗(yàn),

全部參數(shù)的構(gòu)造函數(shù)的自動(dòng)生成,該注解的作用域也是只有在實(shí)體類上,參數(shù)的順序與屬性定義的順序一致。

@NoArgsConstructor無(wú)參構(gòu)造函數(shù)

@RequiredArgsConstructor會(huì)生成一個(gè)包含常量(final),和標(biāo)識(shí)了@NotNull的變量 的構(gòu)造方法。

怎么使用它們都有三個(gè)參數(shù)可以設(shè)置

1. String staticName() default "";

如果設(shè)置了它,將原來(lái)的構(gòu)造方法的訪問修飾符將會(huì)變成 私有的,而外添加一個(gè)靜態(tài)構(gòu)造方法,參數(shù)相同,名字是設(shè)置的字符串的名字,訪問修飾符為公有的。

 

AnyAnnotation[] onConstructor() default {};

在構(gòu)造方法上添加注解。使用方法@RequiredArgsConstructor(onConstructor=@__({@AnnotationsGoHere}))}

例如我們?cè)?Spring 項(xiàng)目中需要注入多個(gè)值,寫很多個(gè) @Autowired 很麻煩,就可以使用這種方式:

@Service@RequiredArgsConstructor(onConstructor = @__(@Autowired))public class UserServiceImpl implements IUserService {   private final IUserRepository userRepository;   private final IOrderRepository orderRepository;   ………………

AccessLevel access() default lombok.AccessLevel.PUBLIC;

構(gòu)造函數(shù)訪問修飾符;

@NoArgsConstructor無(wú)參構(gòu)造函數(shù)中還有個(gè)注解 boolean force() default false;

作者的注釋是 If {@code true}, initializes all final fields to 0 / null / false. Otherwise, a compile time error occurs.

設(shè)置為 true 的時(shí)候,初始化所有的參數(shù)為默認(rèn)值,否則編譯錯(cuò)誤。

@Data我自己嘗試了下,我們使用 @Data 注解就可以有下面幾個(gè)注解的功能: @ToString、@Getter、@Setter、@EqualsAndHashCode、@NoArgsConstructor 。

注意的是,同時(shí)使用@Data 和 @AllArgsConstructor 后 ,默認(rèn)的無(wú)參構(gòu)造函數(shù)失效,如果需要它,要重新設(shè)置 @NoArgsConstructor

@Slf4j//類上面注解了,直接調(diào)用 log 即可:log.info(xxxx);@Log使用的是 java.util.logging.Logger ,直接使用 變量 log。

@Builderbulder 模式構(gòu)建對(duì)象。

@Cleanup@Cleanup InputStream in = new FileInputStream(args[0]);@Cleanup OutputStream out = new FileOutputStream(args[1]);自動(dòng)化關(guān)閉流,相當(dāng)于 jdk1.7 種的 try with resource

val類型推導(dǎo)。

val example = new ArrayList<String>(); example.add("Hello, World!");對(duì)應(yīng)的轉(zhuǎn)換后代碼就是:

val example = new ArrayList<String>(); example.add("Hello, World!");@NonNullpublic NonNullExample(@NonNull Person person) {    this.name = person.getName(); }轉(zhuǎn)換后就是:

public NonNullExample(@NonNull Person person) {    if (person == null) {      throw new NullPointerException("person");    }    this.name = person.getName(); }@SneakyThrows翻譯就是暗中拋出異常

當(dāng)我們需要拋出異常,在當(dāng)前方法上調(diào)用,不用顯示的在方法名后面寫 throw

@SneakyThrows(Exception.class)@Synchronized方法中所有的代碼都加入到一個(gè)代碼塊中,默認(rèn)靜態(tài)方法使用的是全局鎖,普通方法使用的是對(duì)象鎖,當(dāng)然也可以指定鎖的對(duì)象。

private final Object lock = new Object();@Synchronized("lock")public void foo() {    // Do something} 


作者:黑馬程序員JavaEE培訓(xùn)學(xué)院

首發(fā):http://java.itheima.com/


分享到:
在線咨詢 我要報(bào)名
和我們?cè)诰€交談!