书接上回
一个题
请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序。
#include <stdio.h>
int check_sys()
{
int a = 1;
return * (char*) &a;
}
int main()
{
int ret == check_sys();
//写一段代码告诉我们当前机器的字节序
//返回1是小端
//返回0是大端
if (ret == 1)
{
printf("小端\n");
}
else
{
printf("大端\n");
}
return 0;
}
其实很简单。只要拿出内存中第一位即可。指针变量如果是char类型,那么一次访问就访问第一个字符,所以也就能够判断了。
看一些题
#include <stdio.h>
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.存储时是补码,打印则是原码。打印时要打印整形,所以要有整形提升,char类型中-1的补码是8个1,要提升,那么前面再加上24个1即可,signed char也是。而unsigned char则是补码也是8个1,但是没有符号位,所以前面补的都是0,这样打印出来后就是255.
下一个
#include <stdio.h>
int main()
{
char a = -128;
printf("%u\n", a);
return 0;
}
补码是11.....10000000。算出补码要输出的话是原码,但是%u表示无符号输出,所以这时候输出的话是个很大的数。输出二进制数111.........10000000对应的十进制数。
那么char到底是如何定义的?:
char有8个bit位,占1个字节,如果列出所有的组合,能列出2^8个二进制。如果是有符号的char,以符号位作区分,正数的补码反码原码都相同,计算他们对应的数值是1-127.而符号位为1的,可以计算出-127- -1,但是10000000是个例外。他是-128.拿出-128的二进制数,,计算他的补码反码,发现补码和原码一样,所以就规定为-128。
无符号的char,范围就是0-255.
结束。