学术资讯 » 学界研圈

  • 首 页
  • 期刊选题
  • 期刊点评
  • 期刊大全
  • 学人博客
  • 编辑征稿
  • 投稿选刊
  • 投稿群聊
  • 学术会议
  • 万维读书
  • SCI/E期刊
  • SSCI期刊
  • AHCI期刊
  • C语言操作寄存器的常见手法

    阅读: 2022/10/20 11:18:42

    使用C语言对寄存器赋值时,常常需要用到C语言的位操作方法。

    把寄存器某位清零

    假设a代表寄存器,且其中本来已有值。如果要把其中某一位清零且其它位不变,代码如下。

    //定义一个变量 a = 1001 1111 b (二进制数)

    unsigned char a = 0x9f;

    //对 bit2 清零

    a &= ~(1<<2);

    //括号中的 1 左移两位,(1<<2) 得二进制数:0000 0100 b//按位取反,~(1<<2) 得 1111 1011 b

    //假如 a 中原来的值为二进制数:a = 1001 1111 b

    //所得的数与 a 作”位与&”运算,a = (1001 1111 b)&(1111 1011 b),

    //经过运算后,a 的值 a=1001 1011 b

    // a 的 bit2 位被被零,而其它位不变。

    把寄存器某几个连续位清零

    由于寄存器中有时会有连续几个寄存器位用于控制某个功能,现假设我们需要把寄存器的某几个连续位清零,且其它位不变,代码如下。

    //若把 a 中的二进制位分成 2 个一组

    //即 bit0、bit1 为第 0 组,bit2、bit3 为第 1 组,

    // bit4、bit5 为第 2 组,bit6、bit7 为第 3 组

    //要对第 1 组的 bit2、bit3 清零

    a &= ~(3<<2*1);

    //括号中的 3 左移两位,(3<<2*1) 得二进制数:0000 1100 b

    //按位取反,~(3<<2*1) 得 1111 0011 b

    //假如 a 中原来的值为二进制数:a = 1001 1111 b

    //所得的数与 a 作”位与&”运算,a = (1001 1111 b)&(1111 0011 b),

    //经过运算后,a 的值 a=1001 0011 b

    // a 的第 1 组的 bit2、bit3 被清零,而其它位不变。

    //上述 (~(3<<2*1)) 中的 (1) 即为组编号; 如清零第 3 组 bit6、bit7 此处应为 3

    //括号中的 (2) 为每组的位数,每组有 2 个二进制位; 若分成 4 个一组,此处即为 4

    //括号中的 (3) 是组内所有位都为 1 时的值; 若分成 4 个一组,此处即为二进制数“1111 b”

    //例如对第 2 组 bit4、bit5 清零

    a &= ~(3<<2*2);

    对寄存器某几位赋值

    寄存器位经过清零操作后就可以方便地对某几位写入所需要的数值了,具体代码如下。

    //a = 1000 0011 b

    //此时对清零后的第 2 组 bit4、bit5 设置成二进制数“01 b ”

    a |= (1<<2*2);

    //a = 1001 0011 b,成功设置了第 2 组的值,其它组不变

    寄存器某位取反

    要对寄存器的某个位进行取反操作,即 1 变 0 ,0 变 1,这可以直接用如下操作。

    //a = 1001 0011 b

    //把 bit6 取反,其它位不变

    a ^=(1<<6);

    //a = 1101 0011 b

    引文格式:冯丹,罗凌,李钰,等. 融入思政教育的程序设计类课程教学探索[J].计算机教育,2022(9):72—76.

    转自:“计算机教育”微信公众号

    如有侵权,请联系本站删除!


    浏览(337)
    点赞(0)
    收藏(0)
  • 上一篇:10.20 | 论文、文学、新传、语言学、教育学、体育类讲座22场:语料库与英语学术论文写作

    下一篇:数据结构线上线下混合式一流课程的学习效果评价探索

  • 首页

  • 文章

  • 期刊

  • 帮助

  • 我的

版权所有 Copyright@2023    备案号:豫ICP备2021036211号