0
点赞
收藏
分享

微信扫一扫

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

伊人幽梦 2022-04-04 阅读 42

书接上回

一个题

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

#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.

结束。

举报

相关推荐

0 条评论