1、在计算机中正负数是如何表示和存储的?
在计算机中数据类型最高位用于标识数据的符号:
最高位为1,表明这个数为负数;
最高位为0,表明这个数为正数
在计算机中用补码表示有符号数(为什么用补码,可以查看《微机原理与接口技术》),规则如下:
正数的补码为正数本身,负数的补码为负数的绝对值各位取反后加1。
对于固定长度的无符号数:
MAX_VALUE + 1 -> MIN_VALUE
MIN_VALUE -> MAX_VALUE
C语言中变量默认为有符号的类型
unsigned关键字声明为无符号类型,C语言中只有整数类型能够声明unsigned变量。
(即:unsigned只能修饰整数类型的变量。)
例1:有符号数的符号位
#include <stdio.h>
int main()
{
char c = -5;
short s = 6;
int i = -7;
printf("%d\n", ( (c & 0x80) != 0 ));
printf("%d\n", ( (s & 0x8000) != 0 ));
printf("%d\n", ( (i & 0x80000000) != 0 ));
return 0;
}
例2:当无符号数与有符号数混合计算时,会将有符号数转换为无符号数后再进行计算,结果为无符号数,可能会造成错误。
#include <stdio.h>
int main()
{
unsigned int i = 5;
int j = -10;
if( (i + j) > 0 )
{
printf("i + j > 0\n");
}
else
{
printf("i + j <= 0\n");
}
return 0;
}
例3:错误使用unsigned,不能将unsigned数据类型当成有符号数进行计算和输出。
#include <stdio.h>
int main()
{
unsigned int i = 0;
for(i=9; i>=0; i--)
{
printf("i = %u\n", i);
}
return 0;
}