【C语言进阶】②数据在内存中存储之经典例题详解

一、题目
1.百度2015年系统工程师笔试题:
  • 请简述大端字节序和小段字节序的概念,并设计一个小程序来判断当前机器的字节序。(10分)

解析:

  1. 上一篇文章已经讲述了大端字节序和小端字节序的概念,这里就不在累述。
  2. 我们来分析一下编程实现:
    (1) 首先,对于机器的存储方式一般就两种:大端和小端;大端字节序是数据的高位存储在内存的低位,小端字节序是数据的低位存储在内存的低位。那么,对于一个变量来说,我们是不是只要判断出内存中的低位是数据的高位还是低位,那么我们就可以知道机器的存储方式。

(2)实现:
在这里插入图片描述

2.经典练习题
2.1 请看下列代码,输出什么?
//输出什么?
#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; }

有没有想到呢?a,b,c是等于-1吗?请看答案!

在这里插入图片描述
为什么呢???

解析

  1. -1是整型数字,要放在char类型中去, 计算机中存的是补码
  2. a,b,c在内存中的存取形式为:
    在这里插入图片描述
  3. 重点来了:a,b都为有符号char类型,高位都是符号位;而c为无符号char类型,高位为数值位!!!
  4. 所以c为11111111
    在这里插入图片描述
2.2代码事例2
#include <stdio.h>
int main()
{
    char a = -128;
    printf("%u\n",a);
    return 0; }

**结果是128??? 请看答案!
在这里插入图片描述
Why???

解析:

  1. %u表示无符号数。
  2. -128为整型在内存中占4个字节,8个比特位的存储形式为:
    在这里插入图片描述
  3. char 类型只占8个bit,即a:10000000,以%u(无符号整型)的形式打印,需要整型提升,为:
    a的值为:11111111 11111111 11111111 10000000 此时在计算机看来这就是正数,,原反补相同,以此打印。
    在这里插入图片描述
3.代码事例3
#include <stdio.h>
int main()
{
    char a = 128;
    printf("%u\n",a);
    return 0; }

答案是128吗?? 请看结果!
在这里插入图片描述
Why???

解析:
在这里插入图片描述

4.代码事例4
4.
int i= -20;
unsigned  int  j = 10;
printf("%d\n", i+j); 
//按照补码的形式进行运算,最后格式化成为有符号整数

答案是-10吗??,请看答案!

恭喜你,做对了!!在这里插入图片描述

解析:
在这里插入图片描述

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

答案是??

死循环:在这里插入图片描述

Why???

解析:

  1. 由前面几题可知,%u为无符号整型,所以i恒大0
  2. 当i减小到0时,它将从32位的最大二进制数开始减,如此往复循环。
6.代码事例6
int main()
{
    char a[1000];
    int i;
    for(i=0; i<1000; i++)
   {
        a[i] = -1-i;
   }
    printf("%d",strlen(a));
    return 0; }

答案是???
在这里插入图片描述
Why???

解析:

  1. a为char类型,它在内存中占8个比特,最高位为符号位;
    正数范围为:0000 0000 - 0111 1111 即:0-127;
    负数范围为:1000 0000 - 1111 1111 即:-128 - 0;
    故:char类型取值范围为:-128 到 127;
  2. 所以计算数组a的长度为:128+127 = 255.
8.代码事例8
#include <stdio.h>
unsigned char i = 0;
int main()
{
    for(i = 0;i<=255;i++)
   {
        printf("hello world\n");
   }
    return

答案是…???

死循环。你做对了吗?

在这里插入图片描述

解析:

  • 由上一题可知,char类型的取值范围为:-128到127,永远不会取到255,故死循环!
二、最后
1.感谢与预告

感谢你的支持,如果本文有错误以及不足之处,请不吝赐教;如果本文对你有所帮助,麻烦你动动小手点个赞,你的支持就是小编最大的动力!
最后,预告一下下一篇文章,详细探究浮点数在内存中的存储方式;点个关注,一起进步!😃😃😃

  • 14
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

白杨Cc

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

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

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

打赏作者

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

抵扣说明:

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

余额充值