Chinaunix首页 | 论坛 | 博客
  • 博客访问: 15074
  • 博文数量: 3
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 37
  • 用 户 组: 普通用户
  • 注册时间: 2015-03-17 10:13
文章分类

全部博文(3)

文章存档

2015年(3)

分类: Java

2015-04-23 15:39:20

        字符串连接操作中StringBuffer的效率要比String高。由于String对象为不可变对象,每次操作String都会重新建立新的对象来保存新的值。这样原来的对象就会被垃圾回收,这也会影响性能的。
         例如使用如下两段代码测试String和StringBuffer的性能,分别对“abcdefghijklmnopqrstuvwxyz”字符串拼接6000次,会发现两者的时间差异明显。

点击(此处)折叠或打开

  1. package com.an.org;

  2. public class TestStingAndStringBuffer {

  3.     public static void main(String[] args) {
  4.         String tempstr = "abcdefghjiklmnopqrstuvwxyz";
  5.         int times = 6000;
  6.         long lstart1 = System.currentTimeMillis();
  7.         String str = "";
  8.         for(int i = 0;i < times;i++){
  9.             str+= tempstr;
  10.         }
  11.         long lend1 = System.currentTimeMillis();
  12.         long time = (lend1-lstart1);
  13.         System.out.println(time);

  14.     }

  15. }
        关于String的代码在我的机器上打印运行时间为1367毫秒。使用StringBuffer的append方法进行进行拼接操作,代码如下:

点击(此处)折叠或打开

  1. package com.an.org;

  2. public class TestStingAndStringBuffer {

  3.     public static void main(String[] args) {
  4.         String tempstr = "abcdefghjiklmnopqrstuvwxyz";
  5.         int times = 6000;
  6.         long lstart1 = System.currentTimeMillis();
  7.         StringBuffer sb = new StringBuffer();
  8.         for(int i = 0;i < times;i++){
  9.             sb.append(tempstr);
  10.         }
  11.         long lend1 = System.currentTimeMillis();
  12.         long time = (lend1-lstart1);
  13.         System.out.println(time);

  14.     }

  15. }
上述代码在我的机器上的打印时间为1毫秒,当times值增大时,两者的差距更加明显。

阅读(1791) | 评论(0) | 转发(0) |
0

上一篇:没有了

下一篇:Android实现推送方式解决方案

给主人留下些什么吧!~~