当前位置: MXJAVA > JAVA开发 > 文章正文

JDK1.5下的String优化

发表于 2008-01-09 | 阅读 866 views

  java中的String是个特殊的类型,它即不是基本类型,也不是真正意义上的变量,而是个固定类型,即final型。所以在写SQL语句或繁琐的字符串表达式的时候,为了提高效率,我们一般使用StringBuffer来代替String。原因是字符串A和字符串B运算后,会生成新的对象C。如下:

  1. String a = "mx"
  2. String b = "java"
  3. String c = a + b; 
  4. System.out.println(c); 

  上面的代码一共有三个String类型的对象,即a、b和a + b。之前我们也说过,因为String类型是固定值,所以运算后java编译器会重新为其分配一块内存用于存放结果。不过,这是jdk1.5以前对String类型运算的处理方式了。1.5以后对String运算进行了优化,以上面的代码为例,使用JDK1.4.2编译后的程序如下:

  1. String s = "mx"
  2. String s1 = "java"
  3. String s2 = s + s1; 
  4. System.out.println(s2); 

  可以看到,编译后的程序中,s2的计算仍然使用了s + s1的方式,换句话说还是生成了第三个字符串对象。那么JDK1.5编译后的程序又是怎样的呢?

  1. String s = "mx"
  2. String s1 = "java"
  3. String s2 = (new StringBuilder()).append(s).append(s1).toString(); 
  4. System.out.println(s2); 

  可以看到,经JDK1.5编译后的代码使用了StringBuilder来进行字符串的运算,如果象上面代码那样仅仅一个运算,那么看不出什么效果(因为在运算时,新创建了一个StringBuilder的对象),若存在大量运算时,效果就非常明显了。因此,在使用JDK1.5以后的版本编程时,字符串加运算就不必在意了。

  在网上看到有些网友在测试JDK1.5的String时,用了下面的方法:

  1. String a = "ab"
  2. String b = "a"
  3. String c = "b"
  4. System.out.println(a == (b + c)); 

  返回true,就认为是JDK1.5对String的优化。其实这是不对的,即使在JDK1.5以前的版本下执行上面这段代码,返回值依然是true。这是因为java有String池的概念。具体请参看《java中的String池》。

Del.icio.us Google书签 Digg Live Bookmark Technorati Furl Yahoo书签 Facebook 百度搜藏 新浪ViVi 365Key网摘 天极网摘 和讯网摘 博拉网 POCO网摘 添加到饭否 QQ书签 Digbuzz我挖网 关键字:
喜欢MXJAVA的文章,那就通过 RSS Feed 功能订阅阅读吧!

我要评论

*

* 绝不会泄露



返回首页 | 关于我们 | 联系我们 | 广告合作 | 友情链接 | 版权声明