您好,登錄后才能下訂單哦!
這篇文章主要講解了JDK 14中如何使用文本塊Text Blocks,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
說起來,Text Blocks是在JDK13中以第一次預覽版本引入的。現在在JDK14中是第二次預覽版本 JEP 368: Text Blocks。
在我們日常的工作中,有時候需要用到一大段的字符串,這些字符串需要換行,需要排版,需要轉義。在一個文本編輯器中,這當然是非常容易的事情。但是在java代碼中,就是一個噩夢了。
雖然IDE可以自動幫我們加上換行甚至可以對字符串進行拼接。但在java程序眼中,添加的諸多額外的代碼破壞了代碼的美感。是任何一個有潔癖的程序員都無法忍受的。
怎么辦? Text Blocks就是來解救大家的。
舉個例子
我們先來個直觀的例子,然后再分析Text Blocks的特點。
還是舉HTML的例子,如果我們想要打印出帶縮減,有格式的html,傳統方法可以這樣做:
String html = "<html>\n" + " <body>\n" + " <p>Hello, world</p>\n" + " </body>\n" + "</html>\n";
上面的代碼看著特別別扭,讓我們看看用文本塊方式怎么做:
String html = """ <html> <body> <p>Hello, world</p> </body> </html> """;
是不是清爽很多,想要立即給文本塊點個贊。
別慌點贊,我們還有更多的東西要討論。
Indentation編排
可能有人又有問題了,文本塊好用是好用,你這輸出結果中,字段前面的空格都去哪了了呀?
這里就要介紹這個概念了:英文名字叫Indentation,中文我把它翻譯為編排。
再看一下上面的代碼,這一次我們把代碼前面的空格以點來表示:
String html = """ ..............<html> .............. <body> .............. <p>Hello, world</p> .............. </body> ..............</html> ..............""";
Indentation的規則就是以最下面的“”“為界,對每一行都移除相同數量的空格。
上面的代碼輸出:
<html>
<body>
<p>Hello, world</p>
</body>
</html>
上面的例子,最下面的”“”剛好在最左邊的位置,如果把“”“向右移動4個空格會發生什么呢?
String html = """ ..............<html> .............. <body> .............. <p>Hello, world</p> .............. </body> ..............</html> ..................""";
輸出結果:
<html>
<body>
<p>Hello, world</p>
</body>
</html>
我們看到輸出結果是不變的,這樣我們又得到一條結論:如果”“”向右移動,則以text block中最左的那一行記錄為準。
如果我們把“”“向左移動四位,就會發現最終的輸出結果每行前面都有四個空格。
這個功能是和String添加的新的String::stripIndent()對于的。
Escaping轉義
還是看一個直觀的例子:
@Test public void useEscape(){ String code = """ " "" \s\s\s\s\s保留這行前面的空白 String text = \""" 這里展示的是escape的用法! \"""; 跟大家說個密碼,這一行很長,我準備分行\ 來寫,哈哈! """; log.info("{}",code); }
輸出結果:
”
""
保留這行前面的空白
String text = """
這里展示的是escape的用法!
""";
跟大家說個密碼,這一行很長,我準備分行來寫,哈哈!
首先可以看到一個雙引號和兩個雙引號都是不用轉義的,直接寫就行了。三個雙引號就需要轉義了。
另外s表示的是一個空格。在需要的時候可以使用。
在一行結尾直接插入,表示這一行太長了,還沒結束。
注意在Text Block中,不管是windows的回車,換行符還是linux的換行符都會轉義成為換行符。
這個轉義功能也對于了String的新方法translateEscapes()。
formatted格式化
最后介紹一下Text block的格式化,和String的格式化是一樣的,舉個SQL的例子:
@Test public void useMethod(){ String query1 = """ SELECT `EMP_ID`, `LAST_NAME` FROM `EMPLOYEE_TB` WHERE `CITY` = '%s' ORDER BY `EMP_ID`, `LAST_NAME`; """; log.info(query1.formatted("我是一個參數")); }
輸出結果:
SELECT `EMP_ID`, `LAST_NAME` FROM `EMPLOYEE_TB`
WHERE `CITY` = '我是一個參數'
ORDER BY `EMP_ID`, `LAST_NAME`;
上面的例子中,我們使用%s來定義占位符。
看完上述內容,是不是對JDK 14中如何使用文本塊Text Blocks有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。