成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Java開發中如何自動填充SQL語句中的公共字段

運維 數據庫運維
枚舉僅僅是一個繼承于 java.lang.Enum、自動生成了 values() 和 valueOf() 方法的普通 Java 類而已,因此枚舉也歸為引用類型了。

[[342935]]

在很久很久以前,我們寫代碼時要慎重的考慮變量的數據類型,比如下面這些:

 

枚舉:盡管在 JDK 5 中增加了枚舉類型,但是 Class 文件常量池的 CONSTANT_Class_info 類型常量并沒有發生任何語義變化,仍然是代表一個類或接口的符號引用,沒有加入枚舉,也沒有增加過“CONSTANT_Enum_info”之類的“枚舉符號引用”常量。所以使用 enum 關鍵字定義常量,盡管從 Java 語法上看起來與使用 class 關鍵字定義類、使用 interface 關鍵字定義接口是同一層次的,但實際上這是由 Javac 編譯器做出來的假象,從字節碼的角度來看,枚舉僅僅是一個繼承于 java.lang.Enum、自動生成了 values() 和 valueOf() 方法的普通 Java 類而已,因此枚舉也歸為引用類型了。

然而到了 JDK 10 時,我們就有了新的選擇,JDK 10 中新增了 var 局部變量推斷的功能,使用它我們可以很 happy 的忘記數據類型這件事了,那它是如何使用的呢?接下來我們一起來看。

1、使用對比

接下來我們就使用對比的方式,來體會一下 var 的作用。

場景一:定義字符串

舊寫法:

  1. String str = "Hello, Java."

新寫法:

  1. var s = "Hello, Java."

PS:這里的舊寫法指的是 JDK 10 之前的版本,而新寫法指的是 JDK 10 以后(包含 JDK 10)的版本。

場景二:數值相加

舊寫法:

  1. int num1 = 111; 
  2. double num2 = 555.666d; 
  3. double num3 = num1 + num2; 
  4. System.out.println(num3); 

PS:當遇到不同類型相加時(int+ double)會發生數據類型向上轉型,因此 num3 就會升級為 double 類型。

新寫法:

  1. var n1 = 111L; 
  2. var n2 = 555.666; 
  3. var n3 = n1 + n2; 
  4. System.out.println(n3); 

場景三:集合

舊寫法:

  1. List<Object> list = new ArrayList<>(); 
  2. list.add("Hello"); 
  3. list.add("Java"); 

新寫法:

  1. var list = new ArrayList<>(); 
  2. list.add("Hello"); 
  3. list.add("Java"); 

場景四:循環

舊寫法:

  1. for (Object item : list) { 
  2.     System.out.println("item:" + item); 
  3. for (int i = 0; i < 10; i++) { 
  4.     // do something... 

新寫法:

  1. for (var item : list) { 
  2.     System.out.println("item:" + item); 
  3. for (var i = 0; i < 10; i++) { 
  4.     // do something... 

場景五:配合 Lambda 使用

舊寫法:

  1. List<Object> flist = list.stream().filter(v -> 
  2.                 v.equals("Java")).collect(Collectors.toList()); 
  3. System.out.println(flist); 

新寫法:

  1. var flist = list.stream().filter(v -> 
  2.              v.equals("Java")).collect(Collectors.toList()); 
  3. System.out.println(flist); 

2、優點分析

通過上面的示例我們可以看出, var 具備兩個明顯的優點:提高了代碼的可讀性和命名對齊。

① 提高了可讀性

我們在沒有使用 var 之前,如果類型的名稱很長就會出現下面的這種情況:

  1. InternationalCustomerOrderProcessor<AnonymousCustomer, SimpleOrder<Book>> orderProcessor =  
  2.     createInternationalOrderProcessor(customer, order); 

當限定每行不能超過 150 個字符的話,變量名就會被推到下一行顯示,這樣整個代碼的可讀性就變得很低。但當我們使用了 var 之后,代碼就變成了這樣:

  1. var orderProcessor = createInternationalOrderProcessor(customer, order); 

從上述的代碼可以看出,當類型越長時,var(可讀性)的價值就越大。

② 命名對齊

在不使用 var 時,當遇到下面這種情況,代碼就是這樣的:

  1. // 顯式類型 
  2. No no = new No(); 
  3. AmountIncrease<BigDecimal> more = new BigDecimalAmountIncrease(); 
  4. HorizontalConnection<LinePosition, LinePosition> jumping = 
  5.   new HorizontalLinePositionConnection(); 
  6. Variable variable = new Constant(6); 
  7. List<String> names = List.of("Java""中文社群"); 

在使用了 var 之后,代碼是這樣的:

  1. var no = new No(); 
  2. var more = new BigDecimalAmountIncrease(); 
  3. var jumping = new HorizontalLinePositionConnection(); 
  4. var variable = new Constant(6); 
  5. var names = List.of("Java""中文社群"); 

從上述代碼可以看出使用了 var 之后,命名對齊了,整個代碼也變得更優雅了。

3、使用規則 & 反例

var 的實現來自于 JEP 286 (改善提議 286),詳情地址 :http://openjdk.java.net/jeps/286

從 JEP 286 的標題“局部變量類型推斷”可以看出,var 只能用于局部變量聲明,也就是說 var 必須滿足以下條件:

  • 它只能用于局部變量上;
  • 聲明時必須初始化;
  • 不能用作方法參數和全局變量(類變量)。

PS:因為 var 的實現必須根據等會右邊的代碼進行類型推斷,因此它不能被賦值 null 或不被初始化。

反例一:未初始化和賦值 null


 

 

反例二:中途類型更改

 

反例三:全局變量

 

反例四:作為返回值

 

4、原理分析

經過前面的使用我們對 var 已經有了初步的認識,但 var 的實現原理是什么呢?

為了搞清楚它的原理,我們對下面的代碼進行了編譯(使用命令 javac MainTest.java):

 

然后我們再用反編譯工具打開被編譯的類發現:var 竟然被替換成一個個確定的數據類型了,如下圖所示:

由此我們可以得出結論:var 關鍵字的實現和它的名字密切相關, var 只是局部類型推斷,它只會在 Java 編碼期和編譯期有效,當類被編譯為 class 文件時,var 就會變成一個個確定的數據類型(通過推斷得出)。 所以我們可以把 var 通俗的理解為 Java 的語法糖,使用它可以讓我們快速優雅的實現業務代碼,但 var 在字節碼層面是不存在的。

總結

本文我們介紹了 var(局部類型推斷)的使用,它可以用在局部變量、 for、Lambda 的變量聲明中,但不能用在全局變量的聲明中,也不能用它作為方法的返回值,并且在聲明時一定要進行初始化(也不能賦值為 null)。使用 var 可以有效的提高代碼的可讀性和命名對齊,它的實現原理,是在編譯期通過等號右側的代碼進行類型推斷,然后再將 var 替換成確定的數據類型。

本文轉載自微信公眾號「碼農小胖哥」,可以通過以下二維碼關注。轉載本文請聯系碼農小胖哥公眾號。 

 

責任編輯:武曉燕 來源: 碼農小胖哥
相關推薦

2025-06-05 01:00:00

2025-05-27 01:44:00

2010-09-03 15:47:40

SQL語句鎖定

2010-09-03 14:39:15

SQLSELECT語句

2010-09-07 13:41:50

SQL語句

2010-09-07 16:38:36

SQL語句SELECT DIST

2010-09-03 14:47:50

SQLSELECT語句

2010-09-03 11:25:58

SQL刪除

2009-04-28 09:38:53

SQL優化物理查詢

2010-04-13 14:43:37

Oracle性能檢測

2010-09-07 14:56:49

SQL語句CASE WHEN

2010-09-07 10:19:31

SQL語句

2010-09-28 15:54:55

SQL替換字段

2024-01-03 17:42:32

SQL數據庫

2010-09-06 09:11:24

SQLUPDATE語句

2022-05-19 23:40:34

SQL語句引號

2011-09-08 16:30:59

SQL Server查詢

2022-03-23 14:04:32

SQL字符串數據類型

2009-03-04 13:10:41

SQL語句INSERTDELETE

2025-05-29 03:00:00

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品综合一区二区 | 欧美一区二区三区视频在线观看 | 99re在线视频免费观看 | 999国产视频 | 欧美天堂在线观看 | 91久久久精品国产一区二区蜜臀 | 草比网站| 成人av一区 | 中文字幕在线视频免费视频 | 久久九九99| 久草视频在线看 | 亚洲精品一区中文字幕乱码 | 日韩成人在线免费观看 | 九九精品热| 欧美在线视频网 | 三级成人片 | 日本三级网 | 欧美精品一区在线 | 欧美一级视频 | 国产在线精品一区二区 | 久久久久国产精品 | 国产亚洲高清视频 | 操操日 | www.一区二区三区 | 亚洲精品国产第一综合99久久 | 国产区在线看 | 操操日| 久久精品无码一区二区三区 | 欧美在线一区二区三区四区 | 国产色婷婷久久99精品91 | 日韩在线小视频 | 狠狠亚洲| 国外成人免费视频 | 亚洲国产精品视频一区 | 国产免费又黄又爽又刺激蜜月al | 亚洲一区二区在线视频 | 亚洲444eee在线观看 | 最新高清无码专区 | 国产一级黄色网 | 国产成人精品999在线观看 | 午夜视频在线 |