1.常量与常量的拼接结果在常量池,原理是编译期优化

public void test1() {
String s1 = "a" + "b" + "c";//等同于"abc"
String s2 = "abc"; //"abc"-定是放在字符串常量池中,将此地址赋给s2
/*
*最终.java编译成.class,再执行. class
* string s1 = "abc";
* string s2 = "abc
*/
System.out.println(s1 == s2); //true
System.out.println(s1.equals(s2)); //true }

2.常量池中不会存在相同内容的常量。

public void test2() {
String s1 = "javaEE";
String s2 = "hadoop";
String s3 = " javaEEhadoop";
String s4 = "javaEE" + "hadoop";//编泽期优化 String s5 = s1 + "hadoop";
String s6 = "javaEE"+ s2;
String s7 = s1 + s2;
System.out.println(s3 == s4);//true
System.out.println(s3 == s5);//false
System.out.println(s3 == s6);//false
System.out.println(s3 == s7);//false
System.out.println(s5 == s6);//false
System.out.println(s5 == s7);//false
System.out.println(s6 == s7);//false
//intern():判断宇符串常量池中是否存在javaEEhadoop值,如果存在,则返回常量池中javaEEhadoop的地址:
//如果字符串常量池中不存在javaEEhadoop,则在常量池中加载一份javaEEhadoop, 并返回此对象的地址。
String s8 = s6.intern();
System.out.println(s3 == s8);//true
}

3.只要其中有一个是变量,结果就在堆中。变量拼接的原理是StringBuilder

public void test3() {
String s1 = "a";
String s2 = "b";
String s3 = "ab";
/*
如下的s1 + s2的执行细节: (变量s是我临时定义的)
1、StringBuilder s = new stringBuilder();
2、s. append("a")
3、s.append("b")
4、s.tostring() --> 约等于new string( "ab")
补充:在jdk5. 0之后使用的是StringBuilder,在jdk5.0之前使用的是stringBuffer
*/
String s4 = s1 + s2;//
System.out.println(s3 == s4);//false
} /*
1.字符串拼接操作不一-定使用的是stringBuilder!
如果拼接符号左右两边都是字符串常量或常量引用,则仍然使用编译期优化,即非stringBuilder的方式。
2.针对于final 修饰类、方法、基本数据类型、引用数据类型的量的结构时,能使用上final的时候建议使用上。
*/
public void test4() {
final String s1 = "a";
final String s2 = "b";
String s3 = "ab";
String s4 = s1 + s2;
System.out.println(s3 == s4);//true
} public void test5() {
String s1 = "javaEEhadoop";
String s2 = "javaEE";
String s3 = s2 + "hadoop";
System.out.println(s1 == s3);//false
final String s4 = "javaEE";//s4:常量
String s5 = s4 + "hadoop";
System.out.println(s1 == s5);//true
}

4.如果拼接的结果调用intern()方法,则主动将常量池中还没有的字符串对象放入池中,并返回此对象地址。

拼接操作的效率对比:

通过StringBuilder 的append()的方式添加字符申的效率要远高于使用String的字符串拼接方式!
详情:1、StringBuilder的append()的方式:自始至终中只创建过-个StringBuilder的对象,使用String的字符串拼接方式:创建过多个StringBuilder和String的对象
   2、使用String的字符串拼接方式:内存中由于创建7铰多的StringBuilder和String的对象, 内存占用更大:如果进行GC,需要花费额外的时间

改进的空间:在实际开发中,如果基本确定要前前后后添加的字符串长度不高于某个限定值highLevel的情况下,建议使用构造器
StringBuilder s = new StringBuilder(highLevel);//new char[highLevel ]

intern()说明

String s = new String("1");
s. intern();//调用此方法之前,字符串常量池中已经存在了"1”
String s2 = "1";
System. out . println(s == s2);//jdk6: false jdk7/8: false
String s3 = new String("1") + new String("1");//s3变量记录的地址为: new String("11")
//执行完上一行代码以后,字符串常量池中,是否存在"11"呢?答案:不存在! !
s3. intern();//在字符串常量池中生成"11”。如何理解: jdk6: 创建了一个新的对象"11", 也就有新的地址。
//jdk7:此时常量中并没有创建"11",而是创建一个指向堆空间
String s4 = "11" ;//s4变量记录的地址:使用的是上一行代码执行时,在常量池中生成的"11”的地址
System. out . println(s3 == s4);//jdk6: false jdk7/8: true

new String("a") + new string("b")创建了几个对象?

对象1: new stringBuilder()
对象2: new string("a")
对象3: 常量池中的"a”
对象4: new String("b")
对象5: 常量池中的"b”

深入剖析: StringBuilder的tostring():
对象6 : new string( "ab")
强调一下,tostring()的调用,在字符串常量池中,没有生成"ab"

JAVA字符串拼接操作规则说明的更多相关文章

  1. JavaScript如何实现字符串拼接操作

    实际应用中,目标字符串的生成可能需要多个数据的拼接. 由于应用频繁,几乎是所有编程语言都必须掌握的操作,当然每种语言具有各自特点. 本文将通过代码实例详细介绍一下JavaScript如何实现字符串拼接 ...

  2. Java 字符串拼接 五种方法的性能比较分析 从执行100次到90万次

    [请尊重原创版权,如需引用,请注明来源及地址] > 字符串拼接一般使用“+”,但是“+”不能满足大批量数据的处理,Java中有以下五种方法处理字符串拼接,各有优缺点,程序开发应选择合适的方法实现 ...

  3. Java 字符串拼接 StringBuilder() StringBuffer

            字符串拼接 普通方式 public class StringDemo2 { public static void main(String[] args) { // 表示获取从1970- ...

  4. Java 字符串拼接四种方式的性能比较分析

    一.简单介绍 编写代码过程中,使用"+"和"contact"比较普遍,但是它们都不能满足大数据量的处理,一般情况下有一下四种方法处理字符串拼接,如下: 1. 加 ...

  5. 羞,Java 字符串拼接竟然有这么多姿势

    二哥,我今年大二,看你分享的<阿里巴巴 Java 开发手册>上有一段内容说:"循环体内,拼接字符串最好使用 StringBuilder 的 append 方法,而不是 + 号操作 ...

  6. Java字符串连接操作的性能问题

    首先,看一段实验程序: package com.test; class StringTest { public static void main(String[] args) { long start ...

  7. learning java 字符串常用操作

    // 字符串索引取值 "; System.)); // 字符串比较 "; "; "; System.out.println(s1.compareTo(s2)); ...

  8. java 字符串拼接

    package com.fh.controller.pacm.checkbill; import com.google.common.base.Joiner; /** * 字符串拼接 * * @aut ...

  9. Java 字符串拼接方式

    import java.util.ArrayList; import java.util.List; import org.apache.commons.lang.StringUtils; impor ...

随机推荐

  1. Topcoder 14719 - RatingProgressAward(最小割)

    题面传送门 神仙最小割--好久没写过网络流了,故写题解以祭之( 首先考虑一个非常 trivial 的问题:如果知道排列顺序之后怎样计算最大值,用脚趾头想一下就能知道是原序列的最大子段和,因为每个课程之 ...

  2. 深入理解 OpenFOAM 环境变量与编译

    操作系统选择 由于 OpenFOAM 在 Linux 平台开发和测试,在非 Linux 平台无法直接对软件进行编译和安装,所以在非 Linux 平台上最简便方法是使用 docker 容器运行 Open ...

  3. No.2 R语言在生物信息中的应用—模式匹配

    目的: 1. 计算自定义模序在所有蛋白质的匹配位点和次数 2. 输出超过阈值的蛋白质序列到Hit_sequences.fasta 3. Hit_sequences.fasta中序列用小写字母,匹配用大 ...

  4. a.out的由来

    用过linux的都知道,在linux下编译链接程序,如果不加-o参数,生成的binary代码的名字都是默认的a.out.一不小心,a.out还会覆盖上次其他code生成的binary代码. a.out ...

  5. Linux搭建yum仓库

    1.安装nginx 2.为nginx搭建共享目录 3.安装createrepo,创建存储库 4.客户端测试 1.安装nginx yum list |grep nginx #查看是否有可用的nginx包 ...

  6. vivo 敏感词匹配系统的设计与实践

    一.前言 谛听系统是vivo的内容审核平台,保障了vivo各互联网产品持续健康的发展.谛听支持审核多种内容类型,但日常主要审核的内容是文本,下图是一个完整的文本审核流程,包括名单匹配.敏感词匹配.AI ...

  7. 振鹏学习Java的第二天!

    一.今日收获 1.了解了eclipse的具体使用方法. 2.学习了Java程序设计完全手册的第一章内容,明白了相关知识. 3.通过看哔哩哔哩的java的教程视频了解了Dos命令及java的变量和常量. ...

  8. MapReduce08 数据清洗(ETL)和压缩

    目录 数据清洗(ETL) ETL清洗案例 需求 需求分析 实现代码 编写WebLogMapper类 编写WebLogDriver类 打包到集群运行 压缩 概念 MR支持的压缩编码 压缩算法对比 压缩性 ...

  9. 63.不同路径II

    目录 63.不同路径Ⅱ 题目 题解 63.不同路径Ⅱ 题目 一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为"Start" ). 机器人每次只能向下或者向右移动 ...

  10. flink02------1.自定义source 2. StreamingSink 3 Time 4窗口 5 watermark

    1.自定义sink 在flink中,sink负责最终数据的输出.使用DataStream实例中的addSink方法,传入自定义的sink类 定义一个printSink(),使得其打印显示的是真正的ta ...