为什么 0x1 被解释为小于 0xC0000000?

qq4*_*qq4 2 c binary hex integer bit-manipulation

我正在学习整数的二进制表示,并尝试编写一个int使用饱和度返回乘以 2的函数。思考过程是,如果值正溢出,函数返回INT_MAX,相反,如果它负溢出,则返回INT_MIN。在所有其他情况下,二进制值左移 1。

我想知道的是为什么我必须将值转换0xC0000000为 anint才能在我传递参数时使我的函数正常工作x = 1

这是我的功能:

int timestwo (int x){
    if(x >= 0x40000000) // INT_MAX/2 + 1
        return 0x7fffffff; // INT_MAX
    else if(x < (int) 0xC0000000) // INT_MIN/2
        return 0x80000000; // INT_MIN
    else
        return x << 1;
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

PSk*_*cik 5

C 中的十六进制(和八进制)文字使用最小的提升(=int或更高等级的类型)类型,有符号或无符号,可以容纳该值。这与十进制文字不同,如果它们没有u/U后缀,则保留在有符号类型中,否则保留在无符号类型中(6.4.4.1p5):

整型文字类型

这使得0xC0000000在具有 32 位整数无符号和比较(或以其他方式通过运算符配对)具有相同等级的有符号的无符号的系统上,有符号强制变为无符号(6.3.1.8),因此没有强制转换,(int)您会得到一个隐含的(unsigned int)x < (unsigned int) 0xC0000000