目錄
@NoArgsConstructor、@AllArgsConstructor、@RequiredArgsConstructor
@Accessors(chain = true):使用鏈式創建
以以下類爲例:
public class User {
int id;
String name;
List<String> list;
}
@Data、@Value
@Data註解在類上,將類提供的所有屬性都添加get、set方法,並添加equals、canEquals、hashCode、toString方法
@Value註解用於修飾類,相當於是@Data的不可變形式,因爲字段都被修飾爲private
和final
,默認的情況下不會生成settter
。還有一點更狠的,默認類本身也是final
的,不能被繼承。
可以看一下這位老哥的帖子:https://blog.csdn.net/weixin_41540822/article/details/86606535
@Setter、@Getter、lombok.config
給類添加set、get方法
參考帖子:https://blog.csdn.net/weixin_41540822/article/details/86606245
@Builder
使用builder模式創建對象
//創建新的對象
User aaa = User.builder().id(1).name("aaa").build();
//修改原有對象的屬性值;要求實體上添加@Builder(toBuilder=true)
aaa = User.toBuilder().id(2).name("bbb).build();
@Singular和@Builder聯合使用
可以給集合更加方便的添加多條數據
@Singular(value = "list")
List<String> list;
User aaa = User.builder().id(1).name("aaa").list("aaa").list("djsij").build();
參考帖子地址:https://blog.csdn.net/weixin_41540822/article/details/86606562
@NoArgsConstructor、@AllArgsConstructor、@RequiredArgsConstructor
可以創造一個無參構造器、或者有參構造器、第三個生成final或者@notnull修飾的無參或者有參構造器
也是這位老哥的帖子:https://blog.csdn.net/weixin_41540822/article/details/86606513
@ToStirng
可以添加一個toString方法
@NotNull
不能爲空,否則拋出空指針異常
@Accessors(chain = true):使用鏈式創建
//添加註解
@Data
@Accessors(chain = true)
//使用方法
User aaa = new User().setId(1).setName("aaa");
@Synchronized、@SneakyThrows
@Sychronized 是一個處理線程安全問題的annotation, 他的使用方法和關鍵字 synchronized比較類似,但是有一些不同點就是,關鍵字synchronized是鎖定當前對象(this指針) , 而@Synchronized則會鎖定一個private的常量。如果當前類中沒有這個常量,就會自動生成一個
@Synchronized
public static void hello(){
System.out.println("hello");
}
@Synchronized
public int hello2(){
System.out.println("hello");
return 1;
}
@Synchronized
public void hello3(){
System.out.println("hello");
}
以下是它生成的方法
private static final Object $LOCK = new Object[0];
private final Object $lock = new Object[0];
private final Object readLock = new Object();
public static void hello() {
synchronized($LOCK) {
System.out.println("hello");
}
}
public int hello2() {
synchronized($lock) {
return 1;
}
}
public void hello3() {
synchronized(readLock) {
System.out.println("hello");
}
}
@SneakyThrows讓你的代碼擁有try....catch包裹
@SneakyThrows
public static void throwException() {
String str = null;
String[] split = str.split(",");
System.out.println(split);
}
實際上
public SneakyThrowsTest() {}
public static void throwException() {
try {
String str = null;
String[] split = ((String)str).split(",");
System.out.println(split);
} catch (Throwable var2) {
throw var2;
}
}
@Cleanup: 關閉流、連接點
用於處理寫入寫出流的異常問題,可以讓代碼簡潔
使用前:
public class Cleanup01 {
public static void main(String[] args) throws IOException {
InputStream in = new FileInputStream(args[0]);
try {
OutputStream out = new FileOutputStream(args[1]);
try {
byte[] b = new byte[1000];
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();
}
}
}
}
使用後:
public class Cleanup01 {
public static void main(String[] args) throws IOException {
@Cleanup InputStream in = new FileInputStream(args[0]);
@Cleanup OutputStream out = new FileOutputStream(args[1]);
byte[] b = new byte[1000];
while (true) {
int r = in.read(b);
if (r == -1) break;
out.write(b, 0, r);
}
}
}
@Log
https://blog.csdn.net/weixin_41540822/article/details/86606632
@EqualsAndHashCode
重寫equals和hashcode方法。
@UtilityClass
官方文檔是這麼說的
創建實用程序類的註釋。如果使用註釋了一個類,則會@UtilityClass
發生以下情況:
它被標記爲最終。
如果在其中聲明瞭任何構造函數,則會生成錯誤。否則,將生成一個私有的無參數構造函數。它拋出一個UnsupportedOperationException
。
所有方法,內部類和類中的字段均標記爲靜態。
@ExtensionMethod
設置父類
@FieldDefaults
設置屬性的使用範圍,如private、public等,也可以設置屬性是否被final修飾。