4066|2

732

帖子

2

TA的资源

纯净的硅(中级)

楼主
 

删繁就简--1 bit的查找,看了白版主的0bit查找的感想 [复制链接]

本帖最后由 汤权 于 2016-9-23 11:25 编辑

首先算法是白版的,我之前做了一个自己的简单的嵌入式操作系统,就是使用查找位1的位置来进行任务调度的,一开始使用查找表法,这种方法定位速度很快,但是占用很多空间。后来想用循环的方式查找最高有效的bit1位,但是效率不高。有幸看见白版的查找0bit的方法,我就稍加修改了一下,写了一个最高有效bit1查找,可以用在我的小的系统里面了。在此感谢白版的启发@白丁

int bit1search(unsigned int data)
{
        int pos = 0;
        if((data | 0x0000ffff) != 0x0000ffff)
        {
                data >>= 16;
                pos += 16;
        }
        if((data | 0x000000ff) != 0x000000ff)
        {
                data >>= 8;
                pos += 8;
        }
        if((data | 0x0000000f) != 0x0000000f)
        {
                data >>= 4;
                pos += 4;
        }
        if((data | 0x00000003) != 0x00000003)
        {
                data >>= 2;
                pos += 2;
        }
        if((data | 0x00000001) != 0x00000001)
        {
                data >>= 1;
                pos += 1;
        }
        return pos;
}

int bit1search_for(unsigned int data)
{
        int pos = 0,i;
        for(i=0;i<32;i++)
        {
                if(data & (1 << i))
                        pos = i;
        }
        return pos;
}

程序很简单,也是使用二分法的,整体效率比循环稳定。第二个函数是用来测试第一个函数是不是对的,当然结果是对的。。。
此帖出自编程基础论坛

最新回复

  详情 回复 发表于 2016-11-14 20:59

赞赏

1

查看全部赞赏

点赞 关注(1)
个人签名亚里士缺德
 

回复
举报

9176

帖子

6

TA的资源

管理员

沙发
 
感谢分享经验
此帖出自编程基础论坛
加EE小助手好友,
入技术交流群
EE服务号
精彩活动e手掌握
EE订阅号
热门资讯e网打尽
聚焦汽车电子软硬件开发
认真关注技术本身
 
 
 

回复

356

帖子

0

TA的资源

一粒金砂(中级)

板凳
 
此帖出自编程基础论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表