分析:负数在内存中以二进制补码形式保存,按代码运行时,
a的值满足要求,short int 包含有符号和无符号型,可以正确输出-1;
b是由unsigned int型定义的,是无符号型,所以b的值,即-1不能正确输出,结果可能时不可知的一个数
实验代码:
#include<stdio.h>
int main()
{
short int a=-1;
short unsigned int b=-1;
printf("a=%d b=%u",a,b);
return 0;
}
实验截图:
结果及分析:a=ffffffff a=37777777777 b=6.553500e+004 b=ffff
负数a和b在内存中以二进制补码形式保存,运行时,
该程序将a分别以十六进制和八进制输出,将b换成浮点型后以科学计数法形式以及直接以十六进制输出。
实验代码:
#include<stdio.h>
int main()
{
short int a=-1;
short unsigned int b=-1;
printf("a=%x a=%o b=%e b=%x \n",a,a,(float)b,b);
return 0;
}
实验截图:
猜想:输出结果应该是b=2.2345671 单精度浮点型的有效数字是7位
所以最后一位的1应该不会被保存下来
实验代码:
#include<stdio.h>
int main()
{
float a=1.2345671,b;
b=a+1;
printf("b=%f",b);
return 0;
}
实验截图:
实验分析:
char a=’x’;即将字符x保存在了字符型变量a中,再分别以字符型和x对应的ASCII码值,即120输出,字符型数据在内存中本就以ASCII码值保存在。
实验代码:
#include<stdio.h>
int main()
{
char a='x';
printf("a=%c,a=%d",a,a);
return 0;
}
实验截图:
实验分析:
char c[50],即定义了一个长度为50的字符型数组,用来储存字符型数据,再以%s即字符串的形式输出,即原封不动输出原来定义的字符数据。
实验代码:
#include<stdio.h>
int main()
{
char c[50]="这是最后一题了,贼开心!";
printf("%s",c);
return 0;
}
实验截图: