我意识到这是一件微不足道的事情,但是我无法解决。
假设我正在处理此消息。这是一个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] 删除。
我来说两句