-2147483647-1的问题,负数 《 正数, 负数 》正数u ,负数 永远》负数u

-2147483647-1的问题 || 负数 < 正数|| 负数 > 正数u || 负数 永远>负数u

一、负数 < 正数   负数u > 正数    (负数u平移,到正数的上一半部分去了)

-1 < 2   true常识

-1 > 2u   true 负数-->无符号数

4294967295 >2u

(-1= 2的32次方-1 = 4294967295 >2u


类似:

-2147483647-1 < 2147483647   true常识

-2147483647-1 > 2147483647u   true 负数-->无符号数

 等价于

2147483648     >   2147483647u

(-2147483647-1 负数---->无符号数 = 2的32次-2147483648 = 2147483648     >   2147483647u)


二、负数 > 负数   负数u>负数u     (负数u平移,仍然保持负数的大小规律


-1 > -2   true常识

-1 > -2u   true(-1,-2都转化为无符号数,但是还是要遵循-1>-2  )

转换为有符号数前后,都是-1>-2

类似:

-2147483647-1 < -2147483647   true

-2147483647-1 < -2147483647u   true



总结:

-1u是转化为最大的无符号数4294967295 

-2147483648u是最小的无符号数2147483648

仍然保持负数的大小规律

            -1 > -2147483647-1

             -1 u> -2147483647-1 u



扩展:

为什么-2147483647-1 而不直接-2147483648

1.因为:

-2147483648是一个常量表达式,而不是一个常量。所以-2147483648被理解为一个“-”号和一个常量值2147483648。对于“-”,是对原值补码进行“取反加1”操作。由于2147483648超出了有符号常量的表示范围,所以变成了unsigned long int或long long int,而写成-2147483647 - 1则可以精确的表示成为32位有符号整数的最小值。


2.《深入理解计算机系统》在P105页,作者给出了INT_MIN在标准头文件limits.h中的定义

 

  1. #define INT_MAX 2147483647 
  1. #define INT_MIN (-INT_MAX - 1) 




#include<stdio.h>
#include<string.h>


int checktruefalse(int a)
{
if(a)
{
printf("   true\n");
return 1;
}
else
{
printf("   false\n");
return 0;
}
}


int main()
{


printf("2147483647 < -2147483648");checktruefalse(2147483647 < -2147483648);
printf("2147483647u < -2147483648");checktruefalse(2147483647u < -2147483648);


printf("2147483647 > -2147483647-1");checktruefalse(2147483647 > -2147483647-1);
printf("2147483647u < -2147483647-1");checktruefalse(2147483647u < -2147483647-1);


printf("0==0u");checktruefalse(0==0u);
printf("\n");


printf("-1 < 0");checktruefalse(-1 < 0);
printf("-1 > 0u");checktruefalse(-1 > 0u);
printf("\n");
printf("-1 < 2");checktruefalse(-1 < 2);
printf("-1 > 2u");checktruefalse(-1 > 2u);
printf("\n");


printf("-1 > -2");checktruefalse(-1 > -2);
printf("-1 > -2u");checktruefalse(-1 > -2u);
printf("\n");


printf("-2147483647-1 == 2147483648u");checktruefalse(-2147483647-1 == 2147483648u);
printf("-2147483647-1 < 2147483647");checktruefalse(-2147483647-1 < 2147483647);
printf("-2147483647-1 < 2147483647u");checktruefalse(-2147483647-1 < 2147483647u);
printf("-2147483647-1 < -2147483647");checktruefalse(-2147483647-1 < -2147483647);
printf("-2147483647-1 < -2147483647u");checktruefalse(-2147483647-1 < -2147483647u);
return 0;
}

猜你喜欢

转载自blog.csdn.net/qq1518572311/article/details/80075927