1、基于上一讲,首先看一下以下代码
//输出什么
int main()
{
char a=-1;
signed char b=-1;
unsigned char c=-1;
printf("a=%d,b=%d,c=%d",a,b,c);
return 0;
}
结果:-1 -1 255
先存储再提升,符号数高位补1,无符号数高位补0.
2、
再看下一道题:
char a=-128;
printf("%u\n",a);
return 0;
结果:4294967168
首先:-128
原码: 10000000 00000000 10000000
反码:11111111 11111111 01111111
补码:11111111 11111111 10000000
补码存入内存中去,a的类型是char,所以是1个字节,就是8个bit位,
那么这里8个bit位是10000000
%d打印十进制有符号数字,%u是指打印十进制的无符号数字
所以接下来需要做整型提升:这里符号为是负数,整型提升高位全部补1
结果:11111111 11111111 10000000
这里打印无符号的十进制数字,无符号数的原码反码,补码一致,
因此换成十进制就是:4294967168
有符号的char的范围是:-128~127
无符号char的范围是:0-255
3、
char a=128;
printf("%u\n",a);
return 0;
结果:4294967168
4、
int i=-20;
unsigned int j=10;
printf("%d\n",i+j);
//按照补码的形式进行运算,最后格式化为有符号整数
5、
#include <stdio.h>
#include <string.h>
int main()
{
char a[1000];
int i;
for(i=0;i<1000;i++)
{
a[i]=-1-i;
}
printf("%d\n",strlen(a));
return 0;
}
结果是:255
因为我们可知上述a[i]里面存放的是-1,-2,-3.......-1000;这里的strlen是字符串的长度,直到 '\0‘ 结束,因此,我们需要找到 '\0‘ 之前的数据。首先作为符号数,-1......-128之后就变成127,126,125......1,之后就是'\0‘,所以长度为255。
6、
#include <stdio.h>
unsigned char i=0;
int main()
{
for(i=0;i<255;i++)
{
printf("Hello, World!\n");
}
return 0;
}
打印出死循环个Hello, World!
char里面存放了0~255,因为i在这个地方永远都成立的,因此来说255+1=0 。