zoukankan      html  css  js  c++  java
  • 位运算和取模运算的运算效率对比

    前言

      总说计算机是擅长于做位运算的,那么到底它有多擅长呢?

      通过简单的测试,来探究一样位运算和取模运算的运算效率对比。

    一、测试代码:

     1 public class BitAndModulus {
     2     @Test
     3     public void bit() {
     4         int number = 10000 * 10;//分别取值10万、100万、1000万、1亿
     5         int a = 1;
     6         
     7         long start = System.currentTimeMillis();
     8         for(int i = number; i > 0 ; i++) {
     9             a &= i;
    10         }
    11         long end = System.currentTimeMillis();
    12         System.out.println("位运算耗时: " + (end - start));
    13     }
    14     
    15     @Test
    16     public void modulus() {
    17         int number = 10000 * 1000;//分别取值10万、100万、1000万、1亿
    18         int a = 1;
    19         
    20         long start = System.currentTimeMillis();
    21         for(int i = number; i > 0; i++) {
    22             a %= i;
    23         }
    24         long end = System.currentTimeMillis();
    25         System.out.println("取模运算耗时: " + (end - start));
    26     }
    27 }

    二、测试结果:(时间单位:毫秒)

      计算次数     位运算      取模运算    倍数(位运算:取模运算)
      10万:       734      20489    27
      100万:        742      20544    27
      1000万:      735      20408    27
      1亿:       712     19545     27

    三、结论

      位运算确实比取模运算快得多,大约快了27倍。

    作者:赖皮梅
    声明:
    1.原创博文,欢迎转载、引用;转载、引用请注明作者并附上原文链接,否则保留追究法律责任的权利。
    2.本博文中引用他人的博文内容时均已注明出处,如有侵权,请联系作者删除。
    3.博文内容如有错误、不妥之处,欢迎留言指正,还请不吝赐教 =^_^=
  • 相关阅读:
    Java SSM 框架相关基础面试题
    JPanel JScrollPanel
    Spring MVC 的 Converter 和 Formatter
    JDesktopPane JInternalFrames
    Spring MVC 中的 forward redirect Flash属性
    Java Swing 中使用 EventQueue
    Java 中转换为String类型的四种方法
    Eclipse 安装使用 M2Eclipse 插件
    正则表达式
    Spring MVC 数据绑定和表单标签库
  • 原文地址:https://www.cnblogs.com/laipimei/p/11316812.html
Copyright © 2011-2022 走看看