Java int类型转String类型两种方式性能差异

在LeetCode刷题的过程中遇到了一道题解答如下:

List<String> list = new ArrayList<>();
Arrays.sort(hand);
for (int i: hand){
    list.add(i+"");
}
for (int i = 0; i < hand.length / W; i++){
  int first = Integer.parseInt(list.get(0));
  for (int j = 0; j < W; j++){
    list.remove(first+j+"");
  }
}

提交后返回超时。在无法降低时间或空间复杂度的情况下尝试使用s=String.valueOf(i);的方式替代s=i+"";使int类型转为String类型。成功通过提交。

修改后代码:

List<String> list = new ArrayList<>();
Arrays.sort(hand);
for (int i: hand){
    list.add(String.valueOf(i));
}
for (int i = 0; i < hand.length / W; i++){
    int first = Integer.parseInt(list.get(0));
    for (int j = 0; j < W; j++){
        list.remove(String.valueOf(first+j));
    }
}    

 

原因:s=i+""; 会产生两个String对象,而 s=String.valueOf(i); 直接使用String类的静态方法,只产生一个对象。没有内存分配的过程,使程序运行时间降低通过提交。

不知道s=i+""相对 s=String.valueOf(i)有什么优势?知道的同学欢迎在评论下面留言。

posted @ 2018-08-30 15:10  gene1994  阅读(860)  评论(0编辑  收藏  举报