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


    前言

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

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

    一、测试代码:

     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.博文内容如有错误、不妥之处,欢迎留言指正,还请不吝赐教 =^_^=
  • 相关阅读:
    html5 video标签如何禁止视频下载
    Redis源代码-数据结构Adlist双端列表
    HTML5分析实战WebSockets基本介绍
    Chromium on Android: Android在系统Chromium为了实现主消息循环分析
    Android AIDL使用特定的解释
    [LeetCode]Maximum Product Subarray
    OC省字典的数组摘要集
    CocoaChina 第四个测试
    Java在的时候,类定义HashSet初始化方法
    WSHPSRS-匹克选择列表生成器-SRS(R12.2.3)
  • 原文地址:https://www.cnblogs.com/laipimei/p/11316812.html
Copyright © 2020-2023  润新知