項目中經常使用bean
,entity
等類,絕大部分數據類類中都需要get
、set
、tostring
、equals
和hashcode
方法,雖然eclipse
和idea
開發環境下都有自動生成的快捷方式,但自動生成這些代碼后,如果bean
中的屬性一旦有修改、刪除或增加時,需要重新生成或刪除get/set
等方法,給代碼維護增加負擔。而使用了lombok
則不一樣,使用了lombok
的注解(@setter,@getter,@tostring,@@requiredargsconstructor,@equalsandhashcode或@data)之后,就不需要編寫或生成get/set
等方法,很大程度上減少了代碼量,而且減少了代碼維護的負擔。故強烈建議項目中使用lombok
,去掉bean中get、set、tostring、equals和hashcode等方法的代碼。
一、實戰
1.安裝lombok插件:
具體流程如圖:
1.1
1.2
1.3
2.添加lombok的maven的pom.xml依賴:
1
2
3
4
5
|
<dependency> <groupid>org.projectlombok</groupid> <artifactid>lombok</artifactid> <version> 1.16 . 10 </version> </dependency> |
3. 示例代碼student.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
package com.lombok.demo; import lombok.equalsandhashcode; import lombok.getter; import lombok.setter; import lombok.tostring; /** **/ @setter @getter @tostring @equalsandhashcode public class student { private string name; private int age; private string male; private string studentno; } |
4. 測試類lomboktest.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
package com.lombok.demo; import lombok.extern.java.log; @log public class lomboktest { public static void main(string[] args) { student student = new student(); student.setage( 27 ); student.setmale( "man" ); student.setname( "lance" ); student.setstudentno( "2017" ); system.out.println(student.tostring()); student student2 = new student(); student2.setage( 27 ); student2.setmale( "man" ); student2.setname( "lance" ); student2.setstudentno( "2017" ); system.out.println(student.equals(student2)); student2.setstudentno( "2018" ); system.out.println(student.equals(student2)); log.info( "lombok test" ); } } |
5. 輸出結果:
student(name=lance, age=27, male=man, studentno=2017)
true
false
lombok test
結果分析,如果沒有添加@setter
注解,則lomboktest
中的student
示例無法使用setage()
等方法。使用lombok
之后,省去了許多沒必要的get,set,tostring,equals,hashcode代碼,簡化了代碼編寫,減少了代碼量。
另外@data
注解的作用相當于 @getter @setter @requiredargsconstructor @tostring @equalsandhashcode的合集。
另外@log
省去了在lomboktest
中添加 getlogger
的如下代碼:
1
|
private static final java.util.logging.logger log = java.util.logging.logger.getlogger(logexample. class .getname()); |
看,簡單吧!
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對服務器之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
原文鏈接:https://blog.csdn.net/zhglance/article/details/54931430