IT产品热门报价
 手机 更多>>
 笔记本 更多>>
 数码产品 更多>>
 电脑硬件 更多>>
·注册淘宝会员购买便宜数码

·北京 ·上海 ·广州
·杭州 ·深圳 ·合肥
·天津 ·西安 ·宁波
·南京 ·重庆 ·南宁

IT热点
  • 电脑硬件
  • 手机
  • MP4
  • 品牌机
  • 办公产品
  • 投影机
  • 服务器
  • 奥林巴斯
  • 尼康
  • 佳能
  • 阿尔卡特
  • 索尼
  • 微星
  • 七彩虹
  • 笔记本
  • 数码相机
  • 数码摄像机
  • 惠普
  • 戴尔
  • 联想
  • 诺基亚
  • 摩托罗拉
  • 索尼爱立信
  • LG
  • 西门子
  • 飞利浦
  • 华硕
  • 硕泰克
  • 首页 >> 学院 >> 程序开发 >> 程序开发Java
    漫谈Java程序的性能优化 [程序开发Java]
    java研究组
    2006-1-13 23:39:00 文/
      Java使得复杂应用的开发变得相对简单,毫无疑问,它的这种易用性对Java的大范围流行功不可没。然而,这种易用性实际上是一把双刃剑。一个设计良好的Java程序,性能表现往往不如一个同样设计良好的C++程序。在Java程序中,性能问题的大部分原因并不在于Java语言,而是在于程序本身。养成好的代码编写习惯非常重要,比如正确地、巧妙地运用java.lang.String类和java.util.Vector类,它能够显著地提高程序的性能。下面我们就来具体地分析一下这方面的问题。

      在java中,使用最频繁、同时也是滥用最多的一个类或许就是java.lang.String,它也是导致代码性能低下最主要的原因之一。请考虑下面这个例子:

      String s1 = "Testing String";
      String s2 = "Concatenation Performance";
      String s3 = s1 + " " + s2;
      几乎所有的Java程序员都知道上面的代码效率不高。那么,我们应该怎么办呢?也许可以试试下面这种代码:

      StringBuffer s = new StringBuffer();
      s.append("Testing String");
      s.append(" ");
      s.append("Concatenation Performance");
      String s3 = s.toString();
      这些代码会比第一个代码片段效率更高吗?答案是否定的。这里的代码实际上正是编译器编译第一个代码片段之后的结果。既然与使用多个独立的String对象相比,StringBuffer并没有使代码有任何效率上的提高,那为什么有那么多的Java书籍批评第一种方法、推荐使用第二种方法?

      第二个代码片段用到了StringBuffer类(编译器在第一个片段中也将使用StringBuffer类),我们来分析一下StringBuffer类的默认构造函数,下面是它的代码:

      public StringBuffer() { this(16); }
      默认构造函数预设了16个字符的缓存容量。现在我们再来看看StringBuffer类的append()方法:

      public synchronized StringBuffer append(String str) {
      if (str == null) {
      str = String.valueOf(str);
      }
      int len = str.length();
      int newcount = count + len;
      if (newcount >value.length) expandCapacity(newcount);
      str.getChars(0, len, value, count);
      count = newcount; return this;
      }
      append()方法首先计算字符串追加完成后的总长度,如果这个总长度大于StringBuffer的存储能力,append()方法调用私有的expandCapacity()方法。expandCapacity()方法在每次被调用时使StringBuffer存储能力加倍,并把现有的字符数组内容复制到新的存储空间。

      在第二个代码片段中(以及在第一个代码片段的编译结果中),由于字符串追加操作的最后结果是“Testing String Concatenation Performance”,它有40个字符,StringBuffer的存储能力必须扩展两次,从而导致了两次代价昂贵的复制操作。因此,我们至少有一点可以做得比编译器更好,这就是分配一个初始存储容量大于或者等于40个字符的StringBuffer,如下所示:

      StringBuffer s = new StringBuffer(45);
      s.append("Testing String");
      s.append(" ");
      s.append("Concatenation Performance");
      String s3 = s.toString();
      再考虑下面这个例子:

      String s = "";
      int sum = 0;
      for(int I=1; I<10; I++) {
      sum += I;
      s = s + "+" +I ;
      }
      s = s + "=" + sum;
      分析一下为何前面的代码比下面的代码效率低:

      StringBuffer sb = new StringBuffer();
      int sum = 0;
      for(int I=1;
      I<10; I++){
      sum + = I;
      sb.append(I).append("+");
      }
      String s = sb.append("=").append(sum).toString();
      原因就在于每个s = s + "+" + I操作都要创建并拆除一个StringBuffer对象以及一个String对象。这完全是一种浪费,而在第二个例子中我们避免了这种情况。

    ·IT产品报价大全
    更多相关: 手机
    在百度中更多内容: 手机


    [第一页] 1 2 [下一页] [最后一页]
    ·强贴整理:高手的140个电脑技巧
    ·专业:电脑维修的基本原则和方法
    ·05年台湾电子营收五哥排名落定
    ·话题:谈谈办公三大品牌的印象!
    ·老鸟谈数码相机,你会选择谁?
    ·办公族防衰老锦囊 懒人清理术
    ·日出日落拍摄技巧之三好法则
    ·真实拍摄假尼姑的变身术(图)
    ·女人故事:一个肯背你上楼的男人
    ·成都第一美女 回头率1000%辣妹
    ·钟丽缇大扮妖妇 FIFA小姐写真
    ·女人最消魂部位 让你放弃抵抗

    打印此页 投稿与建议 返回顶部

    相关文章