当前位置: 首页 > news >正文

Java入门到精通Java 15中的 3 个双引号语法

Java 中的 3 个双引号 """ 是什么语法?

这是 Java 15 新出的,刷新你的认知!

  • 前言

在 Java 15 的推出的时候,Text Blocks 正式转正,我叫它 “文本块” 好了,栈长也做了简单介绍,没看过的可以点击这里看下。

文本块,是一个多行字符串,它可以避免使用大多数转义符号,自动以可预测的方式格式化字符串,并让开发人员在需要时可以控制格式。

文本块最早准备在 JDK 12 添加的,但最终撤消了,然后在 JDK 13 中作为预览特性进行了添加,然后又在 JDK 14 中再次预览,在 JDK 15 中,文本块终于转正,暂不再做进一步的更改。

  • 示例

来看下这个 HTML 语言示例你就懂了:

不使用 Text Blocks::

String html1 = "\n" +

" \n" +

"

Hi, Java技术栈

\n" +

"

欢迎关注,分享更多干货

\n" +

" \n" +

"\n";

使用 Text Blocks:

String html2 = """

Hi, Java技术栈

欢迎关注,分享更多干货

""";

文本块需要用三个双引号包起来,熟悉 Python 的都知道,三个双引号表示多行注释,没想到 Java 竟然用作了多行字符串…

再来看下字节码:

看到了吧?文本块编译后会自动添加换行符,和原始的拼接写法编译结果一致,再也不用再拼接字符串了。

三、详细介绍

其实文本块的作用远不止换行符这么简单,下面栈长详细介绍下。

1、Line terminators(换行符)

如上面介绍,编译期自动增加换行符可以用来增强用非 Java 语言编写的代码的字符串的可读性,比如我们经常要拼接 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"""

还可以定义一个空的文本块:

String empty = """

""";

一个空字符串也需要两行代码,所以这个方式是不推荐使用的。

2、Incidental white space(空格编排)

继续看上面那段代码:

注意这根线没有,线前面有一排空格,意味着是不会被编译进去的,只是用来缩进格式化方便阅读,所以我叫它空格编排。

如果 """ 在最后单独占一排,则以它左对齐,否则以最靠左的一列左对齐。

IDEA 真是强大啊,对 JDK 15 都支持这么好了。如果你说没激活码,这都不是事,可以关注公众号Java技术栈,回复:idea,栈长教你免费获取正版。

另外,Java 15 中新增了 String.stripIndent 实例方法,可以直接删除每一行的开头和结尾空白字符。

3、Escape sequences(转义字符)

如下面代码所示:

我在代码中又增加了 \s、\n、\t 之类的转义字符,可以直接拿来用,双引号也不需要转义。

结果输出:

Hi, "Java技术栈"

欢迎关注,\分享"更多"干货

实际工作中可能出现的 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";

""";

当然,拼接 SQL 要注意别造成 SQL 注入漏洞了,这里只是介绍使用。

另外,Java 15 新增了一个 String.translateEscapes 转义方法,可以直接对字符串内容进行转义。

4、格式化参数

Java 15 之前格式化字符串中的参数需要使用 String.format 静态方法,感觉不是很方便,而在 Java 15 中新增了直接格式化字符串的方法:

对上面的 SQL 语句进行扩展下,参数使用占位符进行格式化:

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("深圳", "栈长"));

结果输出:

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

WHERE "CITY" = '深圳' AND author = '栈长'

ORDER BY "EMP_ID", "LAST_NAME";

直接使用字符串对象的 formatted 实例方法感觉更方便了!

四、结语

解读 Text Blocks(文本块)远比想象中要难很多,没想到一个文本块这么多细节,文中只是对文本块作了一个部分总结,并不是文本块的全部内容,反正暂时也用不到,大家简单了解即可。

文章来源:网络 版权归原作者所有

上文内容不用于商业目的,如涉及知识产权问题,请权利人联系小编,我们将立即处理

http://www.gsyq.cn/news/1594880.html

相关文章:

  • 【课程设计/毕业设计】基于Java+springboot的热门电影网站观看的设计与实现【附源码、数据库、万字文档】
  • 荧光共振能量转移(FRET)原理与应用浅析
  • 如何快速构建个性化桌面数字伙伴:DyberPet开源框架终极指南
  • Gemma 2实战部署与分层蒸馏:从滑动窗口到MMLU Pro验证
  • 百度网盘秒传脚本终极指南:5分钟掌握永久文件分享的黑科技
  • SO-FSCL算法:极化码软输出解码原理与工程实现详解
  • LangChain 家族生态全解析:从框架到企业级平台的选择指南
  • OpenCore Legacy Patcher终极教程:让老Mac焕发新生体验最新macOS
  • 如何用Python快速获取A股行情数据?mootdx完整指南
  • 成都旅游攻略之茶品选购:适合新手小白的选茶建议
  • 盘锦盛缘全屋定制风格该怎么选
  • LinkSwift:重新定义网盘下载体验的技术解耦方案
  • 大湾区汽配厂海外建厂亏损760万,全链路落地方案6个月降本24%
  • 废标风险一网打尽 埃文AI标书内置实时法规库的三大校验场景
  • 八大网盘直链下载助手:免费解锁下载限速的终极解决方案
  • 3分钟搞定!BetterNCM安装器:网易云音乐插件管理终极神器
  • paperxie AI PPT 生成器|网页端一站式制作汇报幻灯片,告别熬夜排版
  • AI智能体分类及其应用解析(9)
  • YOLO骨干网络改进-第15篇:EfficientNetV2 compound scaling缩放策略
  • 6款论文降AI率平台横评:键清零AI痕迹,这款性价比封神
  • 优刻得GPU+GLM-5+vLLM推理落地实战:A10高性价比部署指南
  • 双材料打印服务,精准定制每一件精品
  • OpenCore Legacy Patcher终极指南:让老Mac重获新生,体验最新macOS系统
  • BooruDatasetTagManager:如何用多模型融合技术将AI数据集构建效率提升5倍?
  • AI 与数字化重塑新能源经销服务:下沉市场门店的转型实践拆解
  • 如何永久保存微信聊天记录?5步掌握数据备份与年度报告生成
  • 北京永强数据恢复中心北京排名第一硬盘电机不转故障数据恢复
  • CAT1 RTU工业物联网方案:TCP+Modbus+GNSS三合一设计
  • C 语言指针数据隐藏难题:从原理困惑到巧妙解决
  • Cpp2IL:如何用这个终极工具破解Unity IL2CPP代码保护