首页 > 代码库 > 包装类型、装箱拆箱、基本类型速度比较
包装类型、装箱拆箱、基本类型速度比较
首先是包装类型
Long sum = Long.valueOf(0); long t1 = System.currentTimeMillis(); for (Long i = Long.valueOf(0); i < Integer.MAX_VALUE/2; i++) { sum += i; } t1 = System.currentTimeMillis() - t1; System.out.println("packaging took "+ t1 +" sum = "+ sum);
耗时:12759ms
装箱拆箱
Long sum = 0L; long t0 = System.currentTimeMillis(); for (long i = 0; i < Integer.MAX_VALUE/2; i++) { sum += i; } t0 = System.currentTimeMillis() - t0; System.out.println("Unboxing Boxing took "+ t0 +" sum = "+ sum);
耗时:6144ms
基本类型
long s = 0L; long t2 = System.currentTimeMillis(); for (long i = 0L; i < Integer.MAX_VALUE/2; i++) { s += i; } t2 = System.currentTimeMillis() - t2; System.out.println("prime took "+ t2 +" sum = "+ s);
耗时:581ms
速度之差立杆见影,基本类型的速度约是包装类型的21倍,装箱拆箱的10倍。
装箱拆箱那段代码是容易写错的地方,一个大小写之差。
优先使用基本类型的论点是有道理的。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。