• 位运算和取模运算的运算效率对比


    前言

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

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

    一、测试代码:

     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.博文内容如有错误、不妥之处,欢迎留言指正,还请不吝赐教 =^_^=
  • 相关阅读:
    《Qt学习系列笔记》--章节索引
    Qt-绘制图表
    Qt-可视化数据库操作
    Qt-数据库操作SQLite
    古人说的最好,临渊羡鱼,不如退而结网, 这是个勇气问题.
    阿里云产品之数据中台架构
    使用HSDB查看类变量的内存布局(5)
    文件流
    类文件介绍
    类的连接之重写(1)
  • 原文地址:https://www.cnblogs.com/laipimei/p/11316812.html
Copyright © 2020-2023  润新知