Java数组拷贝/复制的效率比较

今天在研究Jlibrtp代码时,偶然注意到里面大量使用了System.arraycopy()这个方法,心想既然是协议实现,那用的方法肯定都是效率最高或较高的了,以前对这个System.arraycopy()仅有个抽象的认识。另外,JDK中对ArrayList的add与remove方法的实现,居然也是用的System.arraycopy(),让我不由得对其产生“敬意啊”。今天就来动手试一下到底谁的效率高,到底有多高。

C程序员们经常讨论数组复制的效率,此类笔试面试题也层出不穷。在Java中,数组拷贝可以用:1)for循环;2)clone方法;3)System.arraycopy()。测试如下:

(1)使用了一个70元素的字符串数组;

(2)每种方法各循环拷贝N次。

统计结果如下:

重复1000次

10万

100万

500万

for循环

0

47

484

2421

clone方法

0

32

250

1235

System.arraycopy

0

16

94

437

很明显了,for循环最慢,约为clone方法的2倍,约为System.arraycopy的4~5倍;System.arraycopy最快。

PS:System.arraycopy是调用的JNI,怪不得。

附测试代码:

Java代码 收藏代码
  1. package copytest;
  2. public class ArrayCopyTest
  3. {
  4. private static String [] src
  5. = {"Aaaaaaaaaa", "Vvvvvvv", "Bbbb", "Cccc", "Dddd", "Eddeee", "FFFFFFffffffff",
  6. "Aaaaaaaaaa", "Vvvvvvv", "Bbbb", "Cccc", "Dddd", "Eddeee", "FFFFFFffffffff",
  7. "Aaaaaaaaaa", "Vvvvvvv", "Bbbb", "Cccc", "Dddd", "Eddeee", "FFFFFFffffffff",
  8. "Aaaaaaaaaa", "Vvvvvvv", "Bbbb", "Cccc", "Dddd", "Eddeee", "FFFFFFffffffff",
  9. "Aaaaaaaaaa", "Vvvvvvv", "Bbbb", "Cccc", "Dddd", "Eddeee", "FFFFFFffffffff",
  10. "Aaaaaaaaaa", "Vvvvvvv", "Bbbb", "Cccc", "Dddd", "Eddeee", "FFFFFFffffffff",
  11. "Aaaaaaaaaa", "Vvvvvvv", "Bbbb", "Cccc", "Dddd", "Eddeee", "FFFFFFffffffff",
  12. "Aaaaaaaaaa", "Vvvvvvv", "Bbbb", "Cccc", "Dddd", "Eddeee", "FFFFFFffffffff",
  13. "Aaaaaaaaaa", "Vvvvvvv", "Bbbb", "Cccc", "Dddd", "Eddeee", "FFFFFFffffffff",
  14. "Aaaaaaaaaa", "Vvvvvvv", "Bbbb", "Cccc", "Dddd", "Eddeee", "FFFFFFffffffff"};
  15. private static String [] dst;
  16. /**
  17. * @param args
  18. */
  19. public static void main(String[] args)
  20. {
  21. // TODO Auto-generated method stub
  22. System.out.println(forCopy(5000000));
  23. System.out.println(cloneCopy(5000000));
  24. System.out.println(systemJNICopy(5000000));
  25. }
  26. /**
  27. * 使用for来复制数组
  28. * @param time 循环执行的次数
  29. * @return 执行的总时间
  30. */
  31. public static long forCopy(int time)
  32. {
  33. long start = System.currentTimeMillis();
  34. while(time-- > 0)
  35. {
  36. int size = src.length;
  37. dst = new String [size];
  38. for (int i = 0; i < size; i++)
  39. {
  40. dst[i] = src[i];
  41. }
  42. }
  43. long end = System.currentTimeMillis();
  44. return (end - start);
  45. }
  46. public static long cloneCopy(int time)
  47. {
  48. long start = System.currentTimeMillis();
  49. while(time-- > 0)
  50. {
  51. dst = (String[])src.clone();
  52. }
  53. long end = System.currentTimeMillis();
  54. return (end - start);
  55. }
  56. public static long systemJNICopy(int time)
  57. {
  58. long start = System.currentTimeMillis();
  59. while(time-- > 0)
  60. {
  61. int size = src.length;
  62. System.arraycopy(src, 0, dst, 0, size);
  63. }
  64. long end = System.currentTimeMillis();
  65. return (end - start);
  66. }
  67. }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值