前言
🎈大家好,我是何小侠🎈
🍃大家可以叫我小何或者小侠🍃
💐希望能通过写博客加深自己对于学习内容的理解💐
🌸也能帮助更多人理解和学习🌸
合抱之木,生于毫末;九层之台,起于累土;千里之行,始于足下。
解释:合抱的大树,生长于细小的萌芽;极高的高台,筑起于每一堆泥土;千里的远行,是从脚下第一步开始走出来的。
这篇博客我们将会讲解一些整型在内存中存储的题目,可以来试试自己的理解是否到位。
赛前提示如果你是新手,可以去看看这篇两篇博客: 整型提升: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 也就是说会变成一个死循环。
总结🍊
这篇博客值得我们好好学习,能让我们对内存的了解更上一层楼!
最后如果这篇博客有帮助到你,欢迎点赞关注加收藏
如果本文有任何错误或者有疑点欢迎在评论区评论