zoukankan      html  css  js  c++  java
  • 第十五讲 位图

    位图还是比较简单的,他要解决找第一个1的问题。

    比如有一个32bit的数据,0xFF00000000,从低位开始,他的第一个1是在24位,那么返回值就是24,这个机制是用在任务优先级的某些机制上的。

    这个怎么实现呢,循环移位其实是很容易实现的,但是太慢,因为这个机制会经常用到,所以要搞一个简单的方式。所以用倒推的方式,做了一个表格来实现这个功能。表格怎么做呢?

    1、把32位分成了4个8位进行查找

    2、先找到不为0的那段8个

    3、这段8个有256个数字,0x0-0xFF,这个256个数字,第1个1,出现在哪里,都是可以算出来的,然后就可以填到表格里面去了。

    4、在利用这个表格计算的时候,所有这4个8段,都是一样的,然后加上偏移值,就可以算出第一个1的位置了。

    if (bitmap->bitmap & 0xFF)
        {
            return quickFindTable[bitmap->bitmap & 0xFF];
        }
        else if (bitmap->bitmap & 0xFF00)
        {
            return quickFindTable[(bitmap->bitmap >> 8) & 0xFF] + 8;
        }
        else if (bitmap->bitmap & 0xFF0000)
        {
            return quickFindTable[(bitmap->bitmap >> 16) & 0xFF] + 16;
        }
        else if (bitmap->bitmap & 0xFF000000)
        {
            return quickFindTable[(bitmap->bitmap >> 24) & 0xFF] + 24;
        }
        else
        {
            return tBitmapPosCount();
        }

    比如这个32位的值是FF110000,那么需要查找quickFindTable表格中第0x11个,也就是第17个数字,然后再加上16。其实我们已经知道了0xFF110000,他的第一个1出现在第16位,那么这个表格的第17个值,就是0。这个表格就是这么反推形成的。ucOS用的就是类似的位图。

  • 相关阅读:
    html5 canvas 小例子 旋转的时钟
    用深度学习(CNN RNN Attention)解决大规模文本分类问题
    生成式对抗网络GAN 的研究进展与展望
    linux 系统信息查看
    cmd 更改字体
    查看sbt版本
    机器学习算法汇总
    spark 大数据 LR测试
    spark
    hadoop生态圈介绍
  • 原文地址:https://www.cnblogs.com/nasduc/p/8495765.html
Copyright © 2011-2022 走看看