JAVA中int转String门类效率比较

JAVA中int转String类型效率比较

大家都知道JAVA中 int 类型要转化成 String 类型,可以有三种方式,分别是:
* (1) String.valueOf(i)
* (2) Integer.toString(i)
* (3) i+""


因为前两天,写一个程序时,要用到 int 转 String ,并且数据量很大,因此想看看这三种方式的效率怎样,写了一下简单的测试程序,在此记录一下。

Java代码 JAVA中int转String门类效率比较
  1. public class TestIntToStr {   
  2.     
  3.  public static void main(String[] args) {   
  4.   int[] intArr = new int[1000000];   
  5.   String[] strArr1 = new String[1000000];//为了公平分别定义三个数组   
  6.   
  7.   String[] strArr2 = new String[1000000];   
  8.   String[] strArr3 = new String[1000000];   
  9.   //赋值   
  10.   Long t1 = System.currentTimeMillis();   
  11.   for(int i=0;i<1000000;i++){   
  12.    intArr[i]=i+1;   
  13.   }   
  14.   Long t2 = System.currentTimeMillis();   
  15.   for(int i=0;i<1000000;i++){   
  16.     strArr1[i] = String.valueOf(intArr[i]);     
  17.   }   
  18.   Long t3 = System.currentTimeMillis();   
  19.   for(int i=0;i<1000000;i++){   
  20.    strArr2[i] = Integer.toString(intArr[i]);   
  21.   }   
  22.   Long t4 = System.currentTimeMillis();   
  23.   for(int i=0;i<1000000;i++){   
  24.    strArr3[i] = intArr[i]+"";   
  25.   }   
  26.   Long t5 = System.currentTimeMillis();   
  27.   System.out.println("t1 = "+t1);   
  28.   System.out.println("t2 = "+t2);   
  29.   System.out.println("t3 = "+t3);   
  30.   System.out.println("t4 = "+t4);   
  31.   System.out.println("t5 = "+t5);   
  32.   System.out.println("赋值:"+(t2-t1));   
  33.   System.out.println("String.valueOf(i):"+(t3-t2));   
  34.   System.out.println("Integer.toString(i):"+(t4-t3));   
  35.   System.out.println("i+\"\":"+(t5-t4));   
  36.   
  37.  }   
  38.   
  39. }  
public class TestIntToStr { public static void main(String[] args) { int[] intArr = new int[1000000]; String[] strArr1 = new String[1000000];//为了公平分别定义三个数组 String[] strArr2 = new String[1000000]; String[] strArr3 = new String[1000000]; //赋值 Long t1 = System.currentTimeMillis(); for(int i=0;i<1000000;i++){ intArr[i]=i+1; } Long t2 = System.currentTimeMillis(); for(int i=0;i<1000000;i++){ strArr1[i] = String.valueOf(intArr[i]); } Long t3 = System.currentTimeMillis(); for(int i=0;i<1000000;i++){ strArr2[i] = Integer.toString(intArr[i]); } Long t4 = System.currentTimeMillis(); for(int i=0;i<1000000;i++){ strArr3[i] = intArr[i]+""; } Long t5 = System.currentTimeMillis(); System.out.println("t1 = "+t1); System.out.println("t2 = "+t2); System.out.println("t3 = "+t3); System.out.println("t4 = "+t4); System.out.println("t5 = "+t5); System.out.println("赋值:"+(t2-t1)); System.out.println("String.valueOf(i):"+(t3-t2)); System.out.println("Integer.toString(i):"+(t4-t3)); System.out.println("i+\"\":"+(t5-t4)); } }



在JDK1.5环境下测试多次:

发现:

赋值:0
String.valueOf(i):891
Integer.toString(i):468
i+"":844



String.valueOf(i)与i+""的时间差别不大。



而Integer.toString(i)时间只有它们的一半左右,即此方法效率比较高。

1 楼 huangqingyong 2011-03-24  
楼主可以看一下jdk的源码:
  String类:

         
public static String valueOf(int i) {
              return [color=red]Integer.toString(i, 10)[/color];
          }



  Integer类:

  
 public static String toString(int i, int radix) {
        ……
	/* Use the faster version */
	if (radix == 10) {
	    return [color=red]toString(i)[/color];
	}
	……
	return new String(buf, charPos, (33 - charPos));
    }

    public static String toString(int i) {
        if (i == Integer.MIN_VALUE)
            return "-2147483648";
        int size = (i < 0) ? stringSize(-i) + 1 : stringSize(i);
        char[] buf = new char[size];
        getChars(i, size, buf);
        return new String(0, size, buf);
    }


所以Integer.toString(i)方法的效率比较高。但i+""内部的处理机制是怎样的呢?
2 楼 lucky16 2011-04-18  
huangqingyong 写道
楼主可以看一下jdk的源码:
  String类:

         
public static String valueOf(int i) {
              return Integer.toString(i, 10);
          }



  Integer类:

  
 public static String toString(int i, int radix) {
        ……
	/* Use the faster version */
	if (radix == 10) {
	    return toString(i);
	}
	……
	return new String(buf, charPos, (33 - charPos));
    }

    public static String toString(int i) {
        if (i == Integer.MIN_VALUE)
            return "-2147483648";
        int size = (i < 0) ? stringSize(-i) + 1 : stringSize(i);
        char[] buf = new char[size];
        getChars(i, size, buf);
        return new String(0, size, buf);
    }


所以Integer.toString(i)方法的效率比较高。但i+""内部的处理机制是怎样的呢?

i+""应该是使用了StringBuffer的append(), 结束的时候调用了toString()这个方法   JAVA中int转String门类效率比较