如果在阅读过程中发现有错误,望评论指正,大家一起学习,一起进步。
第2课 有符号与无符号
数据类型的最高位用于表示数据的符号
最高位为1,表明这个数为负数
最高位为0,表示这个数为整数
int sign = 0;
char i = -5;
short j = 5;
int k = 1;
sign = (i & 0x80); // sign unequal to 0
sign = (i & 0x80); // sign equal to 0
sign = (i & 0x80); // sign unequal to 0
有符号数的表示法
在计算机内部用补码表示有符号数
正数的补码为整数本身
负数的补码为负数的绝对值各位取反后加1
8位整数5的补码为: 0000 0101
8位整数-7的补码为: 1111 1001
16位整数20的补码为: 0000 0000 0000 0000
16位整数-13的补码为: 1111 1111 1111 0011
举例:-7
7 ==>111 ==>0000 0111 ==> 1111 1000 ==>1111 1001
无符号的表示法
在计算机内部用原码表示无符号数
无符号数默认为正数
无符号数没有符号位
对于固定长度的无符号数
MAX_VALUE + 1 —-> MIN_VALUE
MIN_VALUE - 1 —-> MAX_VALUE
signed和unsigned
C语言中变量默认为有符号的类型
unsigned关键字声明变量为无符号类型
include <stdio.h>
int main()
{
int i;
signed int j; //默认为带符号整型
unsigned int k; //显示声明变量为带符号整数
return 0; //声明变量为无符号整型
}
C语言中只有整数类型能够声明unsigned变量。
实例程序
2-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-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;
}
当有符号数与无符号数共存是,则有符号数视为无符号数
2-3 错误的使用unsigned
#include <stdio.h>
int main()
{
unsigned int i = 0;
for(i=9; i>=0; i--)
{
printf("i = %u\n", i);
}
return 0;
}
无符号数最小值为0
小结:
有符号数用补码表示
正数的符号位为0
负数的符号位为1
无符号数用原码表示
无符号数没有符号位
无符号数只用于表示正数
unsigned只能修饰整数类型的变量
当无符号数与有符号数混合计算时,会将有符号数转换为无符号数后再进行计算,结果为无符号数