的读数中,可以使用一个添加和一些位操作来添加两个整数。我试图将此方法概括为添加四个8位整数。
uint32_t a, b;
uint32_t c = a + b;
uint32_t r = a ^ b ^ c; // calculate all carry
uint32_t s = r & (0x01010100); // carry of only the digits that we care
uint32_t sum = c - s; // undo the carry on these digits
a = 0xfffeff00 // (-1,-2,-1, 0)
b = 0x01010100 // ( 1, 1, 1, 0)
预期的结果是
0x00ff0000
。它运行
c = 0x01000000 // ( 1, 0, 0, 0)
r = 0xfffffe00 // (-1,-1,-2, 0)
s = 0x01010000 // ( 1, 1, 0, 0)
sum=0xffff0000 // (-1,-1, 0, 0)
sum
的前两个数字变为
ff
(代表
-1
),但正确的数字应为0
。这是因为在减去c = 01 00 00 00
到s = 01 01 00 00
时,第二组的减法溢出并影响第一组的结果。
我想改善解决这个问题的最后一步,但无法找到一个很好的解决方案。当你做的时候
uint32_t sum = c - 2;
可能会导致借口
-s
0x01010000
0x01000000
但也迫使二阶字节变为
0x01
,从而使结果弄乱了。
更好的解决方案是toiterate the随身携带的步骤,直到没有新的不需要的跨字节携带。示例:
0x00