例一:[看了威哥视频,下面更好理解]

package sunjava;
public class String_test {
public static void main(String[] args) {
String str1 = "hello world";
String str2 = new String("hello world");
String str3 = "hello world";
String str4 = new String("hello world"); System.out.println(str1==str2);
System.out.println(str1==str3);
System.out.println(str2==str4);
}
}

结果:

false
true
false

--------------

总结: 

一、String str1 = "hello world";和String str3 = "hello world"; 都在编译期间生成了 字面常量和符号引用,运行期间字面常量"hello world"被存储在运行时常量池(当然只保存了一份)。通过这种方式来将String对象跟引用绑定的话,JVM执行引擎会先在运行时常量池查找是否存在相同的字面常量,如果存在,则直接将引用指向已经存在的字面常量;否则在运行时常量池开辟一个空间来存储该字面常量,并将引用指向该字面常量。

二、通过new关键字来生成对象是在堆区进行的,而在堆区进行对象生成的过程是不会去检测该对象是否已经存在的。因此通过new来创建对象,创建出的一定是不同的对象,即使字符串的内容是相同的。

例二:

package sunjava;
public class String_test {
public static void main(String[] args) {
String string = "";
for(int i=0;i<10000;i++){
string += "hello";
}
}
}

上面new出了10000个对象,修改方案如下

public class Main { 

    public static void main(String[] args) {
StringBuilder stringBuilder = new StringBuilder();
for(int i=0;i<10000;i++){
stringBuilder.append("hello");
}
}
}

上面new操作只进行了一次,也就是说只生成了一个对象

继续优化

用StringBuffer是线程安全的。

二、测试案例

public class String_test {
private static int time = 50000;
public static void main(String[] args) {
testString();
testStringBuffer();
testStringBuilder();
test1String();
test2String();
} public static void testString () {
String s="";
long begin = System.currentTimeMillis();
for(int i=0; i<time; i++){
s += "java";
}
long over = System.currentTimeMillis();
System.out.println("操作"+s.getClass().getName()+"类型使用的时间为:"+(over-begin)+"毫秒");
} public static void testStringBuffer () {
StringBuffer sb = new StringBuffer();
long begin = System.currentTimeMillis();
for(int i=0; i<time; i++){
sb.append("java");
}
long over = System.currentTimeMillis();
System.out.println("操作"+sb.getClass().getName()+"类型使用的时间为:"+(over-begin)+"毫秒");
} public static void testStringBuilder () {
StringBuilder sb = new StringBuilder();
long begin = System.currentTimeMillis();
for(int i=0; i<time; i++){
sb.append("java");
}
long over = System.currentTimeMillis();
System.out.println("操作"+sb.getClass().getName()+"类型使用的时间为:"+(over-begin)+"毫秒");
} public static void test1String () {
long begin = System.currentTimeMillis();
for(int i=0; i<time; i++){
String s = "I"+"love"+"java";
}
long over = System.currentTimeMillis();
System.out.println("字符串直接相加操作:"+(over-begin)+"毫秒");
} public static void test2String () {
String s1 ="I";
String s2 = "love";
String s3 = "java";
long begin = System.currentTimeMillis();
for(int i=0; i<time; i++){
String s = s1+s2+s3;
}
long over = System.currentTimeMillis();
System.out.println("字符串间接相加操作:"+(over-begin)+"毫秒");
} }

结果:

操作java.lang.String类型使用的时间为:4485毫秒
操作java.lang.StringBuffer类型使用的时间为:8毫秒
操作java.lang.StringBuilder类型使用的时间为:3毫秒
字符串直接相加操作:2毫秒
字符串间接相加操作:17毫秒

----------------

总结:

String、StringBuilder、StringBuffer三者的执行效率:

  StringBuilder > StringBuffer > String

  当然这个是相对的,不一定在所有情况下都是这样。

当字符串相加操作或者改动较少的情况下,建议使用 String str="hello"这种形式;

  当字符串相加操作较多的情况下,建议使用StringBuilder,如果采用了多线程,则使用StringBuffer。

参考文章:http://www.cnblogs.com/dolphin0520/p/3778589.html

最新文章

  1. iphone 下滚动条卡顿解决办法
  2. android-数据存储之外部file存储(sdcard)
  3. AngularJS开发指南7:AngularJS本地化,国际化,以及兼容IE低版本浏览器
  4. OpenStack主机列表接口
  5. 《Python CookBook2》 第一章 文本 - 去字符串两端的空格 &amp;&amp; 合并字符串 &amp;&amp; 将字符串逐字符或者逐词反转
  6. 【转】 UINavigationItem UINavigationBar 关系分析
  7. Android自定义属性、控件三步法
  8. 基于visual Studio2013解决算法导论之017查找第n小元素
  9. python_在windows下安装配置python开发环境及Ulipad开发工具
  10. laravel 添加第三方扩展库
  11. [PKU2389]Bull Math (大数运算)
  12. 手动实现一个虚拟DOM算法
  13. LeetCode算法题-Excel Sheet Column Title(Java实现)
  14. Kafka— —副本(均衡负载)
  15. 《Mysql 日志结构》
  16. Kail Linux渗透测试教程之ARP侦查Netdiscover端口扫描Zenmap与黑暗搜索引擎Shodan
  17. [BZOJ1040][ZJOI2008]骑士(环套树dp)
  18. Centos下Apache+Tomcat集群--搭建记录
  19. js 时间对比
  20. spring3: 延迟初始化Bean

热门文章

  1. MorningSale 介绍
  2. JS单例设计模式
  3. 浅谈JavaScript中的原型模式
  4. leetcode&mdash;sqrt
  5. Programming Impala Applications
  6. 恒天云技术分享系列5 – 虚拟化平台性能对比(KVM &amp; VMware)
  7. HDU-4720 Naive and Silly Muggles 圆的外心
  8. 关于ORACLE的硬解析和软解析与MySQL的查询缓存query_cache探讨
  9. 做XH2.54杜邦线材料-导线
  10. UVaLive 7360 Run Step (排列组合,枚举)