java – 为什么分支预测比没有分支更快?
发布时间:2020-12-15 02:59:11 所属栏目:Java 来源:网络整理
导读:灵感来自这个问题: Why is it faster to process a sorted array than an unsorted array? 我写了自己的分支预测实验: public class BranchPrediction { public static void main(final String[] args) { long start; long sum = 0; /* No branch */ start
灵感来自这个问题:
Why is it faster to process a sorted array than an unsorted array? 我写了自己的分支预测实验: public class BranchPrediction { public static void main(final String[] args) { long start; long sum = 0; /* No branch */ start = System.nanoTime(); sum = 0; for (long i = 0; i < 10000000000L; ++i) sum += i; System.out.println(System.nanoTime() - start); System.out.println(sum); /* With branch */ start = System.nanoTime(); sum = 0; for (long i = 0; i < 10000000000L; ++i) if (i >= 0) sum += i; System.out.println(System.nanoTime() - start); System.out.println(sum); /* No branch (again) */ start = System.nanoTime(); sum = 0; for (long i = 0; i < 10000000000L; ++i) sum += i; System.out.println(System.nanoTime() - start); System.out.println(sum); /* With branch (again) */ start = System.nanoTime(); sum = 0; for (long i = 0; i < 10000000000L; ++i) if (i >= 0) sum += i; System.out.println(System.nanoTime() - start); System.out.println(sum); } } 结果让我感到困惑:根据程序输出,带分支的循环比没有分支循环的循环可靠得快. 输出示例: 7949691477 -5340232226128654848 6947699555 -5340232226128654848 7920972795 -5340232226128654848 7055459799 -5340232226128654848 为什么会这样? 编辑: >反汇编类显示Java编译器没有优化(遗漏)任何东西(https://gist.github.com/HouzuoGuo/5692424) 解决方法
请记住,JVM正在内部优化执行,并且PC内部有缓存可以加快计算速度.由于你拥有如此强大的处理器(许多独立核心),因此并不奇怪.另请注意,代码在Java代码下运行,该代码映射到PC的机器代码.只需输入尽可能优化的代码,让JVM担心它.
编辑:大负荷的机器和硬件,它们运行效率更高.特别是缓存. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |