我正在尝试从 16 个元素的字节数组中获取数值(双精度)值,如下所示:
unsigned char input[16];
double output;
...
double a = input[0];
distance = a;
for (i=1;i<16;i++){
a = input[i] << 8*i;
output += a;
}
但它不起作用。似乎包含左移结果的临时变量只能存储 32 位,因为经过 4 次 8 位移位操作后它会溢出。
我知道我可以使用类似的东西
a = input[i] * pow(2,8*i);
但是,出于好奇,我想知道是否有任何使用移位运算符来解决这个问题的方法......