Java数组拼接字符串几个写法性能比较(转载)
将数组 int[] arr = {0,1,2,3,4,5,6,7,8,9} 拼接成 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 字符串:
StringBuilder sb = new StringBuilder(arr.length*3); // StringBuilder(arr.length*3)性能比StringBuilder()高
sb.append("[");
// 写法1
for( int i = 0, len = arr.length; i < len; i++)
{
if( i > 0 ){
sb.append(", ");
}
sb.append(arr[i]);
}
return sb.append("]").toString();
// 写法二
int iMax = arr.length - 1;
for(int i = 0; ; i++){
sb.append(arr[i]);
if( i == iMax ){
return sb.append("]").toString();
}
sb.append(", ");
}
// 写法三
int offset = arr.length - 1;
for( int i = 0; i < offset; i++ )
{
sb.append(arr[i]).append(", ");
}
sb.append(arr[offset]).append("]");
return sb.toString();
性能效率: 写法3 > 写法2 > 写法1
写法3效率之所以高,是因为在 for 循环中去掉了 if 条件判断。