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

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

    如果你做完了可以与下面对一下答案。
    【C语言】整型在内存中存储 赛场(来试试)_第1张图片
    a变量的讲解:
    【C语言】整型在内存中存储 赛场(来试试)_第2张图片

    b变量的讲解:

    在这里插入图片描述

    c变量的讲解
    【C语言】整型在内存中存储 赛场(来试试)_第3张图片
    最后验证:
    【C语言】整型在内存中存储 赛场(来试试)_第4张图片

    第二题

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

    解答:

    【C语言】整型在内存中存储 赛场(来试试)_第5张图片

    【C语言】整型在内存中存储 赛场(来试试)_第6张图片

    【C语言】整型在内存中存储 赛场(来试试)_第7张图片
    验证:
    【C语言】整型在内存中存储 赛场(来试试)_第8张图片

    第三题

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

    你也试一试

    解答:
    【C语言】整型在内存中存储 赛场(来试试)_第9张图片
    【C语言】整型在内存中存储 赛场(来试试)_第10张图片
    是不是有点感觉了呢?
    验证: 【C语言】整型在内存中存储 赛场(来试试)_第11张图片

    第四题

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

    解答:
    【C语言】整型在内存中存储 赛场(来试试)_第12张图片
    【C语言】整型在内存中存储 赛场(来试试)_第13张图片
    这就是相加之前的准备
    下面是相加:

    【C语言】整型在内存中存储 赛场(来试试)_第14张图片
    验证:
    【C语言】整型在内存中存储 赛场(来试试)_第15张图片

    第五题

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

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

    我们来仔细看看
    【C语言】整型在内存中存储 赛场(来试试)_第16张图片
    这是我们调试得出的结果为什么呢?
    讲解:
    【C语言】整型在内存中存储 赛场(来试试)_第17张图片
    上面就是无符号int的大小值,那为什么0 -1会变成4294967295,下面这幅图也应该能够解释
    【C语言】整型在内存中存储 赛场(来试试)_第18张图片

    第六题

    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之前,一共有多少个数。

    【C语言】整型在内存中存储 赛场(来试试)_第19张图片
    我们知道当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

    验证:
    【C语言】整型在内存中存储 赛场(来试试)_第20张图片

    【C语言】整型在内存中存储 赛场(来试试)_第21张图片

    第七题

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

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

    讲解和验证:
    【C语言】整型在内存中存储 赛场(来试试)_第22张图片
    我们看我以前画的这幅图,当i = 255后 再+ 1就会再变成 0 也就是说会变成一个死循环。

    总结

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

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

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

    你可能感兴趣的:(C语言,c语言,笔记,经验分享)