zoukankan      html  css  js  c++  java
  • JDK1.5下的String优化

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

      可以看到,编译后的程序中,s2的计算仍然使用了s + s1的方式,换句话说还是生成了第三个字符串对象。那么JDK1.5编译后的程序又是怎样的呢?
    String s = "mx"String s1 = "java"String s2 = (new StringBuilder()).append(s).append(s1).toString();System.out.println(s2);

      可以看到,经JDK1.5编译后的代码使用了StringBuilder来进行字符串的运算,如果象上面代码那样仅仅一个运算,那么看不出什么效果(因为在运算时,新创建了一个StringBuilder的对象),若存在大量运算时,效果就非常明显了。因此,在使用JDK1.5以后的版本编程时,字符串加运算就不必在意了。 
      在网上看到有些网友在测试JDK1.5的String时,用了下面的方法:
    String a = "ab"String b = "a"String c = "b"System.out.println(a == (b + c));

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

    java中的String池

    先来看看下面这段代码,你知道它的结果吗?

    程序代码
    public class StringTest1{
      public static void main(String[] args) {
        String str1 = "abc";
        String str2 = "abc";
        System.out.println(str1 == str2);
      }
    }


       正确答案应该是true。再来看下面这段代码:


    程序代码
    public class StringTest2 {
      public static void main(String[] args) {
        String str1 = new String("abc");
        String str2 = new String("abc");
        System.out.println(str1 == str2);
      }
    }


       正确答案是false。

       众所周知,java的String是不可改变的字符串对象。为了提高效率,java为String类提供了串池。正如大家所看到的那样,在StringTest1中就使用了串池。当你重新声明一个String型变量为abc时,将使用串池里原来的那个abc,而不重新分配内存,也就是说,str2与str1将会指向同一块内存。所以结果为true。在StringTest2中使用了普通对象的声明方式,系统将会为str1和str2各分配一块内存。所以结果为false。
  • 相关阅读:
    将CMD内的显示内容输出到txt文件
    上传项目到Github
    利用百度地图API,在浏览器中找到自己的位置
    操作系统相关知识
    字符串的全排列
    二维数组做函数参数、指向指针的指针做函数参数
    strstr函数与strcmp函数
    华为机试题——数组排序,且奇数存在奇数位置,偶数存在偶数位置
    单链表的建立,插入,显示,查找删除以及反转
    《深入了解 Linq to SQL》之对象的标识 —— 麦叔叔呕心呖血之作
  • 原文地址:https://www.cnblogs.com/daichangya/p/12960039.html
Copyright © 2011-2022 走看看