博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
取自ACE中的bit操作宏(转)
阅读量:4554 次
发布时间:2019-06-08

本文共 821 字,大约阅读时间需要 2 分钟。

1 # define ACE_BIT_ENABLED(WORD, BIT) (((WORD)  &  (BIT))  !=   0 )2 # define ACE_BIT_DISABLED(WORD, BIT) (((WORD)  &  (BIT))  ==   0 )3 # define ACE_BIT_CMP_MASK(WORD, BIT, MASK) (((WORD)  &  (BIT))  ==  MASK)4 # define ACE_SET_BITS(WORD, BITS) (WORD  |=  (BITS))5 # define ACE_CLR_BITS(WORD, BITS) (WORD  &=   ~ (BITS))

附上C中常用的位运算用法,取自《C Primer Plus》

掩码:即mask,通常为某一个位为1,而其他位都为0的byte,如00000100。
1.把byte中除掩码相同的位外,全部置0,掩码位不变

flags &= mask

   10101111 & 00000100 = 00000100

2.打开位:打开特定的位,其他位不变。

flags |= MASK

00001000 | 00000100 = 00001100

3.关闭位:关闭特定位,但不影响其他位

flags &= ~MASK

11100101 &=  ~10000000 = 01100101

4.转置位:一个位如果打开,则关闭;如果关闭,则打开

flags ^= MASK

11100101 ^=  10000000 = 01100101

11100101 ^=  00010000 = 11110101
5.查看一个位的值:

1 if ((flag & MASK) == MASK)2     do_some_work();

转自:

转载于:https://www.cnblogs.com/zl1991/p/9305867.html

你可能感兴趣的文章
kafka源码阅读环境搭建
查看>>
UI设计
查看>>
androidtab
查看>>
Windows Phone 自定义弹出框和 Toast 通知
查看>>
如何生成静态页面的五种方案
查看>>
php 事件驱动 消息机制 共享内存
查看>>
剑指offer 二叉树的bfs
查看>>
LeetCode Maximum Subarray
查看>>
让我们再聊聊浏览器资源加载优化
查看>>
underscore demo
查看>>
CSS hack
查看>>
C# Enum Name String Description之间的相互转换
查看>>
Android 实现ripple动画
查看>>
PHP wamp server问题
查看>>
Spring Data Redis学习
查看>>
js闭包理解案例-解决for循环为元素注册事件的问题
查看>>
2015.04.23,外语,读书笔记-《Word Power Made Easy》 12 “如何奉承朋友” SESSION 33
查看>>
Spring+SpringMVC+JDBC实现登录
查看>>
生与死之间
查看>>
NEFU 109
查看>>