C语言进阶学习记录——이십오 数据存储(2)

书接上回

目录

请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序

两段代码


请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序

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。

结束。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值