Java jdk对字符串相加的优化。
背景
关于Java对于字符串相加(使用加号+
连接) 的优化。本文讨论几个点
- 这种优化是从jdk几开始做了的?
- 优化做了些什么?
- 没有优化前是怎么做的?
- 优化后就可以为所欲为在任何场景下都使用加号
+
对字串进行相加吗? - 我为啥总记得对String的相加的优化,即优化成StringBuilder是从jdk8之后才有的,认为jdk8之前是效率很低的(曼德拉效应)
-
从jdk5开始就做了的,之后jdk6/7/8都没有改变过,即没有继续进一步优化。jdk9有没有进一步优化就不清楚了,不在本次讨论议题内
-
字符串相加优化成StringBuilder的append
String s1 = "a"; String s2 = s1 + "b"; ====优化后====> String s2 = new StringBuilder().append(s1).append("b").toString(); ---------- 上述是等价的代码,需要知道更多细节可以 javap -v -p 或者 javap -c 或者是通过jclasslib-IDEA插件等工具或方式查看JVM指令,从指令可以窥探到细节 ----------
-
没有优化前,即=jdk5就开始做了,并不是jdk8才做的,jdk8跟jdk5比,没做优化的提升
为什么我总是有个印象,是从jdk8之后才优化成StringBuilder?这是不是传说中的 "曼德拉效应"?
-
其次,在for循环里,不能对字串进行相加,效率很低,每次循环都会产生一个StringBuilder对象,最好是自己在循环外写一个StringBuilder,用这一个就行。
下面的代码,在运行了多次后取了大概的平均值,大概差距是400多倍
method1 耗时:453 method2 耗时:1
public static void main(String[] args) { int times = 1_0000; long startTime = System.currentTimeMillis(); method1(times); System.out.println("method1 耗时:" + (System.currentTimeMillis() - startTime)); startTime = System.currentTimeMillis(); method2(times); System.out.println("method2 耗时:" + (System.currentTimeMillis() - startTime)); } public static void method1(int times) { String s = ""; for (int i = 0; i
关注打赏
热门博文
- 防止电脑睡眠的Java程序
- 怎么在Windows10中找回Windows7的照片查看器(Windows 照片查看器)win10新的照片查看器太难用了
- IDEA的Terminal光标太粗了如何调细
- IDEA的Annotate或Annotate with Git Blame
- 如何搜素git某个分支是否存在?
- `git fetch` 和 `git remote update origin --prune` 的区别(以及跟`git pull` 的区别)
- 分支合并到b和b合并到a有区别吗
- Java 中如何比较两个BigDecimal 以及BigDecimal的坑
- 关于Springboot的@Profile的写法以及多个profile的写法排坑(“!profile1 && !profile2“ 的写法)
- 关于启动springboot如果指定多个profile时相同配置的覆盖规律