用按位和运算符分配值

同步性

我意识到这是一件微不足道的事情,但是我无法解决。

假设我正在处理此消息。这是一个3字的消息,每个字16位。如果我试图编写伪代码进行这些变量分配,这是否正确:

var1 = (word 1) & 0x7FFF

tmp1 = (word 1 >> 15) & 0x0001
tmp2 = (word 2 & 0x3FFF) << 14
var2 = tmp1 + tmp2    

tmp1 = (word 2 >> 14) & 0x0003
tmp2 = (word 3 & 0x7FFF) << 15
var3 = tmp1 + tmp2
哈罗德

不,它不会将来自的位word2放在的正确位置var2,也不会将来自的位word3放在正确的位置var3,如图所示:

0 is a 0 bit,
1 comes from word1
2 comes from word2
3 comes from word3
var1 =     0111 1111 1111 1111 (good)
var2 = ... 2200 0000 0000 0001 (not good)
var3 = ... 3000 0000 0000 0022 (not good)

中间不应有大范围的零。

因为左移太大,所以存在多余的零。它应该是:

var1 = (word 1) & 0x7FFF

tmp1 = (word 1 >> 15) & 0x0001
tmp2 = (word 2 & 0x3FFF) << 1
var2 = tmp1 + tmp2    

tmp1 = (word 2 >> 14) & 0x0003
tmp2 = (word 3 & 0x7FFF) << 2
var3 = tmp1 + tmp2

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章