这篇文章主要讲解了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有进一步的了解,如果还想学习更多内容,欢迎关注亿速云行业资讯频道。