String API 變化
String.indent()
indent 「縮進」這個單詞大家很熟悉了,這是Java12處理字符串的新功能,先來看方法定義:
該方法很簡單,只接收一個 int 類型的參數表示縮進值,這裡的 n 既可以是正數,也可以是負數,只不過是增加空格 space 和移除空格的差別,來看個例子:
<code>String result = "foo\\nbar\\nbar2".indent(4);
System.out.println(result);/<code>
打印結果是這樣的(考驗眼力的時候到了,仔細看截圖在IDE中設置的縮進小點點):
調用 indent 方法會自動添加一個換行符號 \\n ,在該方法的實現中也明確給了註釋說明,目的是為了行終結符的規範化
**注意:**對於 Tab 就是當成一個字符來看到,比如我們把上面的例子稍作修改:
<code>String result = "foo\\nbar\\n\\tbar2".indent(4);
System.out.println(result);/<code>
來看打印結果,注意和上面的不同:
就是這麼簡單,我們繼續向下看
String.transform()
transform 「轉換」,我們經常會遇到字符串形勢轉換的需求,transform方法接收一個 Function 類型的參數, 生成一個全新形式的字符串
<code>List<string> names = List.of( " Alex", "brian");
List<string> transformedNames = new ArrayList<>();
for (String name : names){
\tString transformedName = name.transform(String::strip)
\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t .transform(StringUtils::toCamelCase);
\ttransformedNames.add(transformedName);
}/<string>/<string>/<code>
有朋友可能會說,這個和單純的對字符串 trim 或者其他操作有什麼區別啊?因為接受的參數是 Function類型,當Function類型作為入參時,內部的處理邏輯將增加更多靈活性
Files.mismatch(Path, Path)
有時候,我們需要比較兩個文件的內容是否相同,這個API就派上用場了,該方法比較兩個 path 下的文件,並且返回一個 long 值,這個值表示第一處不匹配的字節位置。如果返回-1,說明兩個文件相等,還是來看個例子:
<code>Path file1 = Paths.get("/Users/fraser/Documents/projects/personal/learning-demo-collection/jdk12-demo/src/file1.txt");
\t\tPath file2 = Paths.get("/Users/fraser/Documents/projects/personal/learning-demo-collection/jdk12-demo/src/file2.txt");
\t\ttry {
\t\t\tlong mismatch = Files.mismatch(file1, file2);
\t\t\tSystem.out.println(mismatch);
\t\t} catch (IOException e) {
\t\t\te.printStackTrace();
\t\t}/<code>
兩個文件內容分別是:
<code>//file1.txt
大家好
//file2.txt
大家好
/<code>
查看運行結果:
建議大家查看一下 mismatch 的實現邏輯,有個小算法在裡面的
Support for Unicode 11 (當個瞭解就好了)
當下,Emoji 表情符號在社交媒體渠道上扮演著重要角色,所以支持最新的 Unicode 規範比以往任何時候都更重要。Java 12保持了同步並支持Unicode 11。Unicode 11增加了684個字符,共137,374個字符,增加了7個新腳本,共146個腳本。
Switch Expressions(Preview)
這個更改擴展了switch語句。為什麼這麼說?
- 語句(我們原來那樣使用)
- 表達式(不必為每個case塊定義一個break語句,我們可以簡單地使用箭頭語法)
- 變量賦值(使用新的switch表達式,我們可以直接將switch語句分配給一個變量)
<code>boolean isWeekend = switch (day)
{
case MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY -> false;
case SATURDAY, SUNDAY -> true;
default -> throw new IllegalStateException("Illegal day entry :: " + day);
};
System.out.println(isWeekend);/<code>
注意: 要使用此預覽特性,請記住,我們必須在應用程序啟動期間使用-enable-preview標誌顯式地指示JVM。
Compact Number Formatting (緊湊的數據格式)
由用戶界面或命令行工具呈現的大數字總是很難展現。使用數字的縮寫形式則要直觀很多。前端為了更有好的數據展現形式,很早就有相應的組件實現了。現在後端小夥伴也可以在java12中應用這個特性了
緊湊的數字表示更易於閱讀,並且在不丟失原始含義的情況下,在屏幕上需要更少的空間。
例子:3.6M 比 3,600,000 容易讀得多
Java 12 引入了一個叫做 NumberFormat.getCompactNumberInstance(Locale, NumberFormat.Style)的靜態方法。用於創建緊湊數字表示形式,來看例子:
<code>\t\tNumberFormat formatter = NumberFormat.getCompactNumberInstance(Locale.US, NumberFormat.Style.SHORT);
\t\tString formattedString = formatter.format(25000L);
\t\tSystem.out.println(formattedString);/<code>
來看運行結果:
另外,CompactNumberFormat 是 NumberFormat的子類,我們可以自定義它的實例(其實就是格式化樣式等),很簡單,這個大家自行查看吧
總結
Java近兩年升級真是太快了,瞭解一些新功能總是沒錯的,大家動手實踐試試吧,以後遇到類似的需求至少能避免我們重複造輪子了.....
靈魂追問
- 你們項目中Java的版本是多少?
- 項目中你會怎樣建議某些工具的升級?
閱讀更多 Java耕耘 的文章