小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

Java入門到精通Java 15中的 3 個(gè)雙引號(hào)語法

 學(xué)掌門 2022-06-20 發(fā)布于上海

Java 中的 3 個(gè)雙引號(hào) """ 是什么語法?

這是 Java 15 新出的,刷新你的認(rèn)知!

一、前言

Java 15 的推出的時(shí)候,Text Blocks 正式轉(zhuǎn)正,我叫它 “文本塊” 好了,棧長也做了簡單介紹,沒看過的可以點(diǎn)擊這里看下。

文本塊,是一個(gè)多行字符串,它可以避免使用大多數(shù)轉(zhuǎn)義符號(hào),自動(dòng)以可預(yù)測的方式格式化字符串,并讓開發(fā)人員在需要時(shí)可以控制格式。

文本塊最早準(zhǔn)備在 JDK 12 添加的,但最終撤消了,然后在 JDK 13 中作為預(yù)覽特性進(jìn)行了添加,然后又在 JDK 14 中再次預(yù)覽,在 JDK 15 中,文本塊終于轉(zhuǎn)正,暫不再做進(jìn)一步的更改。

二、示例

來看下這個(gè) HTML 語言示例你就懂了:

不使用 Text Blocks::

String html1 = "\n" +

              "    \n" +

              "        

Hi, Java技術(shù)棧

\n" +

              "        

歡迎關(guān)注,分享更多干貨

\n" +

              "    \n" +

              "\n";

使用 Text Blocks:

String html2 = """

Hi, Java技術(shù)棧

歡迎關(guān)注,分享更多干貨

              """;

文本塊需要用三個(gè)雙引號(hào)包起來,熟悉 Python 的都知道,三個(gè)雙引號(hào)表示多行注釋,沒想到 Java 竟然用作了多行字符串……

再來看下字節(jié)碼:

看到了吧?文本塊編譯后會(huì)自動(dòng)添加換行符,和原始的拼接寫法編譯結(jié)果一致,再也不用再拼接字符串了。

三、詳細(xì)介紹

其實(shí)文本塊的作用遠(yuǎn)不止換行符這么簡單,下面棧長詳細(xì)介紹下。

1、Line terminators(換行符)

如上面介紹,編譯期自動(dòng)增加換行符可以用來增強(qiáng)用非 Java 語言編寫的代碼的字符串的可讀性,比如我們經(jīng)常要拼接 HTML、XML、SQL 語言代碼等,代碼非常難看。

"""

Java

line 2

line 3

"""

就等同于:

"line 1\nline 2\nline 3\n"

或者:

"line 1\n" +

"line 2\n" +

"line 3\n"

如果最后一行不需要換行,可以這么寫:

"""

line 1

line 2

line 3"""

還可以定義一個(gè)空的文本塊:

String empty = """

""";

一個(gè)空字符串也需要兩行代碼,所以這個(gè)方式是不推薦使用的。

2、Incidental white space(空格編排)

繼續(xù)看上面那段代碼:

注意這根線沒有,線前面有一排空格,意味著是不會(huì)被編譯進(jìn)去的,只是用來縮進(jìn)格式化方便閱讀,所以我叫它空格編排。

如果 """ 在最后單獨(dú)占一排,則以它左對(duì)齊,否則以最靠左的一列左對(duì)齊。

IDEA 真是強(qiáng)大啊,對(duì) JDK 15 都支持這么好了。如果你說沒激活碼,這都不是事,可以關(guān)注公眾號(hào)Java技術(shù)棧,回復(fù):idea,棧長教你免費(fèi)獲取正版。

另外,Java 15 中新增了 String.stripIndent 實(shí)例方法,可以直接刪除每一行的開頭和結(jié)尾空白字符。

3、Escape sequences(轉(zhuǎn)義字符)

如下面代碼所示:

我在代碼中又增加了 \s、\n、\t 之類的轉(zhuǎn)義字符,可以直接拿來用,雙引號(hào)也不需要轉(zhuǎn)義。

結(jié)果輸出:

Hi,  "Java技術(shù)棧"

歡迎關(guān)注,\分享"更多"干貨

實(shí)際工作中可能出現(xiàn)的 SQL 語句的拼寫就有救了!

不使用 Text Blocks:

String query = "SELECT \"EMP_ID\", \"LAST_NAME\" FROM \"EMPLOYEE_TB\"\n" +

               "WHERE \"CITY\" = 'INDIANAPOLIS'\n" +

               "ORDER BY \"EMP_ID\", \"LAST_NAME\";\n";

使用 Text Blocks:

String query = """

               SELECT "EMP_ID", "LAST_NAME" FROM "EMPLOYEE_TB"

               WHERE "CITY" = 'INDIANAPOLIS'

               ORDER BY "EMP_ID", "LAST_NAME";

               """;

當(dāng)然,拼接 SQL 要注意別造成 SQL 注入漏洞了,這里只是介紹使用。

另外,Java 15 新增了一個(gè) String.translateEscapes 轉(zhuǎn)義方法,可以直接對(duì)字符串內(nèi)容進(jìn)行轉(zhuǎn)義。

4、格式化參數(shù)

Java 15 之前格式化字符串中的參數(shù)需要使用 String.format 靜態(tài)方法,感覺不是很方便,而在 Java 15 中新增了直接格式化字符串的方法:

對(duì)上面的 SQL 語句進(jìn)行擴(kuò)展下,參數(shù)使用占位符進(jìn)行格式化:

String query = """

               SELECT "EMP_ID", "LAST_NAME" FROM "EMPLOYEE_TB"

               WHERE "CITY" = '%s' AND author = '%s'

               ORDER BY "EMP_ID", "LAST_NAME";

               """;

        System.out.println(query.formatted("深圳", "棧長"));

結(jié)果輸出:

SELECT "EMP_ID", "LAST_NAME" FROM "EMPLOYEE_TB"

WHERE "CITY" = '深圳' AND author = '棧長'

ORDER BY "EMP_ID", "LAST_NAME";

直接使用字符串對(duì)象的 formatted 實(shí)例方法感覺更方便了!

四、結(jié)語

解讀 Text Blocks(文本塊)遠(yuǎn)比想象中要難很多,沒想到一個(gè)文本塊這么多細(xì)節(jié),文中只是對(duì)文本塊作了一個(gè)部分總結(jié),并不是文本塊的全部內(nèi)容,反正暫時(shí)也用不到,大家簡單了解即可。

文章來源:網(wǎng)絡(luò)  版權(quán)歸原作者所

上文內(nèi)容不用于商業(yè)目的,如涉及知識(shí)產(chǎn)權(quán)問題,請(qǐng)權(quán)利人聯(lián)系小編,我們將立即處理

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多