作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试编写一个 C 函数,它将打印一个由最不重要的单词组成的单词x 的字节,以及 y 的剩余字节。例如,如果 x = 0x89ABCDEF 且 y =0x76543210,这应该给出 0x765432EF,但是如何?
最佳答案
为了操作数据类型中的特定位(或字节),您应该使用按位运算符。
基本的按位运算符是 | (or)、&(and)、^(异或)和 ~(NOT 或补码),它们的工作方式与逻辑运算符 ||、&& 和 ! 有很大不同。
使用您的变量 x = 0x89ABCDEF 和 y = 0x76543210,让我们逐步解决:
首先,这些是 x 和 y 的二进制值:
x = 1000 1001 1010 1011 1100 1101 1110 1111
y = 0111 0110 0101 0100 0011 0010 0001 0000
我已将 32 位分成 4 位一组,以查看十六进制如何转换为二进制。
现在,我们需要取消 x 中除最后一个字节之外的所有字节:操作 (x & 0xFF)
x = 1000 1001 1010 1011 1100 1101 1110 1111
0xFF = 0000 0000 0000 0000 0000 0000 1111 1111
--------------------------------------------------
x & 0xFF = 0000 0000 0000 0000 0000 0000 1110 1111
我们只需要取消设置 y 的最后一个字节:操作 (y & ~0xFF)
y = 0111 0110 0101 0100 0011 0010 0001 0000
~0xFF = 1111 1111 1111 1111 1111 1111 0000 0000 (~ flips all bits)
-----------------------------------------------------
(y & ~0xFF) = 0111 0110 0101 0100 0011 0010 0000 0000
现在,使用“或”运算组合我们的结果:(x & 0xFF) | (y & ~0xFF)
(x & 0xFF) = 0000 0000 0000 0000 0000 0000 1110 1111
(y & ~0xFF) = 0111 0110 0101 0100 0011 0010 0000 0000
------------------------------------------------------------------
(x & 0xFF) | (y & ~0xFF) = 0111 0110 0101 0100 0011 0010 1110 1111
Which in hex is------------7----6----5----4----3----2----E----F
花些时间熟悉这些操作,应该不会有什么麻烦。此外,确保学习其他位运算符(<<、>>、&=、|= 等)
关于c - 我如何获得C中变量的最低有效字节,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12379109/
COW 不是奶牛,是 Copy-On-Write 的缩写,这是一种是复制但也不完全是复制的技术。 一般来说复制就是创建出完全相同的两份,两份是独立的: 但是,有的时候复制这件事没多大必要
我是一名优秀的程序员,十分优秀!