书接上回
目录
请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序
请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序
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类型,那么一次访问就访问第一个字符,所以也就能够判断了。
两段代码
int main()
{
char a = -1;
signed char b = -1;
unsigned char c = -1;
printf("a = %d b = %d c = %d\n", a, b, c);
return 0;
}
结果是-1,-1,255。存储时是补码,打印则是原码。打印时要打印整形,所以要有整形提升,char类型中-1的补码是8个1,要提升,那么前面再加上24个1即可,signed char也是。而unsigned char则是补码也是8个1,但是没有符号位,所以前面补的都是0,这样打印出来后就是255。
下一个
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。有符号的char,范围是-128到127。
结束。