固执的位将不会设置为1。

时间:2018-09-09 22:23:12

标签: c binary ieee-754 ieee

我有这个代码,用于获取IEEE二进制数的尾数或值。

iFloat_t floatGetVal (iFloat_t x) {
  iFloat_t mantissa = (BITS == 16) ? (x & 0x03FF)
                      : (x & 0x007FFFFF);
    debug("%s: getVal before implicit 1", getBinary(mantissa));
    //mantissa = (BITS == 16) ? (mantissa | 0x04)
    //                : (mantissa | 0x008);
    mantissa = x | 0000010000000000;
    debug("%s: getVal after implicit 1", getBinary(mantissa));
    mantissa = (BITS == 16) ? (mantissa & 0x07FF)
                      : (mantissa & 0x00FFFFFF);
    if(floatGetSign(x) == 1) {
        mantissa = ~mantissa + 1;
    }
    return mantissa;
}

我的问题是,当我尝试从数字63.125中获取值时,这是相应的输出:

DEBUG iFloat.c[31] floatGetVal() 0000-0011-1110-0100: getVal before implicit 1
DEBUG iFloat.c[35] floatGetVal() 0101-0011-1110-0100: getVal after implicit 1
DEBUG iFloat.c[81] floatAdd() 0000-0011-1110-0100: bits of val_y after assignment

这是我的预期输出:

DEBUG iFloat.c[31] floatGetVal() 0000-0011-1110-0100: getVal before implicit 1
DEBUG iFloat.c[35] floatGetVal() 0101-0111-1110-0100: getVal after implicit 1
DEBUG iFloat.c[81] floatAdd() 0000-0111-1110-0100: bits of val_y after assignment

这是我的完整代码:

https://pastebin.com/w4UVzmUe

2 个答案:

答案 0 :(得分:7)

let addSelfDestructingEventListener = (element, eventType, callback) => { let handler = () => { callback(); element.removeEventListener(eventType, handler); }; element.addEventListener(eventType, handler); }; 是八进制文字,而不是二进制文字,请使用十六进制0000010000000000

答案 1 :(得分:1)

标准C中没有二进制常量。因此,不能有类似0b0000010000000000的东西。但是,GCC拥有extension,以0b0B前缀来支持它们。

如果您不使用GCC,则最好使用@zch提供的建议。