【C语言】整型在内存中存储 赛场(来试试)

前言
🎈大家好,我是何小侠🎈
🍃大家可以叫我小何或者小侠🍃
💐希望能通过写博客加深自己对于学习内容的理解💐
🌸也能帮助更多人理解和学习🌸

合抱之木,生于毫末;九层之台,起于累土;千里之行,始于足下。
解释:合抱的大树,生长于细小的萌芽;极高的高台,筑起于每一堆泥土;千里的远行,是从脚下第一步开始走出来的。

在这里插入图片描述


    这篇博客我们将会讲解一些整型在内存中存储的题目,可以来试试自己的理解是否到位。
    在这里插入图片描述

    赛前提示如果你是新手,可以去看看这篇两篇博客: 整型提升link 下面题目涉及的数据类型的大小 link

    第一题🍊

    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;
    }
    

    最后打印出来的是什么呢?

    如果你做完了可以与下面对一下答案。
    在这里插入图片描述
    a变量的讲解:
    在这里插入图片描述

    b变量的讲解:

    在这里插入图片描述

    c变量的讲解
    在这里插入图片描述
    最后验证:
    在这里插入图片描述

    第二题🍊

    int main()
    {
        char a = -128;
        printf("%u\n",a);
        return 0;
    }
    

    解答:

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述
    验证:
    在这里插入图片描述

    第三题🍊

    int main()
    {
        char a = 128;
        printf("%u\n", a);
        return 0;
    }
    
    

    你也试一试

    解答:
    在这里插入图片描述
    在这里插入图片描述
    是不是有点感觉了呢?
    验证: 在这里插入图片描述

    第四题🍊

    int main()
    {
    	int i = -20;
    	unsigned  int  j = 10;
    	printf("%d\n", i + j);
    
    }
    

    解答:
    在这里插入图片描述
    在这里插入图片描述
    这就是相加之前的准备
    下面是相加:

    在这里插入图片描述
    验证:
    在这里插入图片描述

    第五题🌸

    5.
    unsigned int i;
    for(i = 9; i >= 0; i--)
    {
        printf("%u\n",i);
    }
    

    这个题目大家能看懂吗?
    是不是 i 从 9 开始然后当i = 0时是最后一次循环吗?
    我既然这么问了当然也就不是上面的想法。
    那到底问题出在哪里呢?

    我们来仔细看看
    在这里插入图片描述
    这是我们调试得出的结果为什么呢?
    讲解:
    在这里插入图片描述
    上面就是无符号int的大小值,那为什么0 -1会变成4294967295,下面这幅图也应该能够解释
    在这里插入图片描述

    第六题🌸

    int main()
    {
        char a[1000];
        int i;
        for(i=0; i<1000; i++)
       {
            a[i] = -1-i;
       }
        printf("%d",strlen(a));
        return 0;
    }
    

    这个题大家思路吗?如果是新手肯定会有点蒙不知道是什么意思?
    strlen不应该是求字符串长度的吗?为什么用在这里。

    如果你实在不能理解我就来告诉你
    讲解:

    其实这个题目的关键就在你能不能理解这里的strlen,我们知道strlen是求字符串中\0之前的字符个数的一个函数,并且返回值是size_t,然后我们要知道一个知识点就是\0在ASCII中的整型值是0。也就是说我们要知道-1-i为0之前,一共有多少个数。

    在这里插入图片描述
    我们知道当i = -1的时候才能让a[ i ]=0,那么 i 怎么才能=-1呢?
    我们看这副我之前我画的图有符号char 的正值范围为 0- 127,
    负值范围为-128~-1我们从上一个题目中可以得知一个规律当 i = 127,
    也就是正值最大值,
    再加1就会变成 -128那么-128再+(-127)就等于-1了,
    也就是说 0 -127 +(-128 ~-2)。
    0-127 一共 128个数-128到-2一共127个数128 + 127 = 255

    验证:
    在这里插入图片描述

    在这里插入图片描述

    第七题🌸

    unsigned char i = 0;
    int main()
    {
        for(i = 0;i<=255;i++)
       {
            printf("hello world\n");
       }
        return 0;
    }
    

    这道题目,是不是就打印256次就不打印了呢?当然不是,已经做了几个这样的题目了我们肯定有点意识了。

    讲解和验证:
    在这里插入图片描述
    我们看我以前画的这幅图,当i = 255后 再+ 1就会再变成 0 也就是说会变成一个死循环。

    总结🍊

    这篇博客值得我们好好学习,能让我们对内存的了解更上一层楼!

    最后如果这篇博客有帮助到你,欢迎点赞关注加收藏

    在这里插入图片描述在这里插入图片描述
    如果本文有任何错误或者有疑点欢迎在评论区评论
    在这里插入图片描述

    在这里插入图片描述

    • 5
      点赞
    • 1
      收藏
      觉得还不错? 一键收藏
    • 打赏
      打赏
    • 3
      评论
    评论 3
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包

    打赏作者

    He XIAO xia

    你的鼓励将是我创作的最大动力

    ¥1 ¥2 ¥4 ¥6 ¥10 ¥20
    扫码支付:¥1
    获取中
    扫码支付

    您的余额不足,请更换扫码支付或充值

    打赏作者

    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

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

    余额充值