当前位置:网站首页>关于数据在内存中存储的相关例题
关于数据在内存中存储的相关例题
2022-06-25 12:35:00 【LIn_jt】
关于数据在内存中的存储例题
本文将讲解数据在内存中存储的相关例题
请看下面几道例题:>
例题一:
#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;
}
输出的结果为:>
整数在内存中存储4个字节, 而将-1存放在char类型的变量中,必然会发生截断, 因此,-1 在这三个变量中都是存放的这样的数据:

而我们打印的时候,以整型的形式来打印, 而这三个变量都为char类型, 因此,这三个变量会发生整型提升, 而整型提升是根据变量的类型来进行的。a进行整型提升时, char类型在vs编译器下默认为signed char类型, 因此, 上面全一序列中,最高位为符号位, 因此整型提升时, 前面补1,得到的序列为:
而打印的时候,以%d的形式来打印, 即以有符号的整型来打印, 因此,上面的全一序列最高位被认为是符号位,为负数, 因此,我们需要将其转化为原码之后进行打印, 转化后也即为-1,因此, 便打印出了-1, 而变量b也是相同的道理。
而c呢?,c与a, b不同的原因便出在整型提升时,变量c的类型为unsigned char, 因此,在整型提升的时候, 其八个1的二进制序列前面会补0,而不会补1.

例题2:
#include <stdio.h>
int main()
{
char a = -128;
printf("%u\n",a);
return 0;
}
输出的结果为:>

分析过程如下:>

也就与在vs环境底下跑出来的数据一样了。
现在我们思考一下, 如果把这里的char a = -128 改为char a = 128, 结果又是怎么样的呢?即
#include <stdio.h>
int main()
{
char a = 128;
printf("%u\n",a);
return 0;
}
其实结果也是和上面 一样的, 因为不管怎么样, 此时a中存放的二进制序列也为10000000, 因此分析结果与上题一样, 得到的结果也会与上题一样。
例题三:>
#include <stdio.h>
int main()
{
int a = -20;
unsigned int b = 10;
printf("%d\n", a + b);
return 0;
}
输出的结果为:>

这时就有同学会说, 哎呀, 这不是很简单的 -20 + 10 = -10吗, 其实,真正的计算结果是这样的:>

这就是计算机真正的计算过程。
下面我们来看例题4:>
#include <stdio.h>
int main()
{
unsigned int i;
for(i = 9; i >= 0; i--)
{
printf("%u\n",i);
}
}
程序输出的结果为:> 死循环
其实很好理解, 因为变量i为unsigned int, 无符号整型数据是必然>=0的。因此, 程序运行的结果为死循环。
例题5:>
int main()
{
char a[1000];
int i;
for (i = 0; i < 1000; i++)
{
a[i] = -1 - i;
}
printf("%d", strlen(a));
return 0;
}
输出的结果为:>
此处,我们需要了解到的是char类型存储数据的最大值和最小值, 因为char类型为一个字节,因此我们可以这样来理解
即:>


因此,对于上面的程序, 我们可以这么理解:.

因此就是我们的255了。
例题6:>
unsigned char i = 0;
int main()
{
for (i = 0; i <= 255; i++)
{
printf("hehe\n");
}
return 0;
}
运行的结果为死循环:>

为什么为死循环呢?其实是因为unsigned char 类似的数据范围在0 ~255之间, 因此永远符合循环条件,进入循环。
边栏推荐
- 20220620 面试复盘
- MySQL adds, modifies, and deletes table fields, field data types, and lengths (with various actual case statements)
- Analyse de l'optimisation de la réécriture des requêtes lazyagg de l'entrepôt
- [flask tutorial] flask development foundation and introduction
- MySQL writes user-defined functions and stored procedure syntax (a detailed case is attached, and the problem has been solved: errors are reported when running user-defined functions, and errors are r
- 出手即不凡,这很 Oracle!
- Talk about 11 key techniques of high availability
- Using CMD (command prompt) to install MySQL & configure the environment
- 剑指 Offer II 032. 有效的变位词
- 三行代码简单修改jar包的项目代码
猜你喜欢

剑指 Offer II 029. 排序的循环链表

Optimization of lazyagg query rewriting in parsing data warehouse

How to implement a high-performance load balancing architecture?

剑指 Offer II 032. 有效的变位词

Sword finger offer day 3 string (simple)

Sword finger offer day 1 stack and queue (simple)

Seven competencies required by architects

Koa 框架

Capabilities required by architects

Sword finger offer day 2 linked list (simple)
随机推荐
20220620 interview reply
Koa 框架
How to implement a high-performance load balancing architecture?
CUDA error: unspecified launch failure
Conway's law can not be flexibly applied as an architect?
英语口语 - 连读
515. Find Largest Value in Each Tree Row
MySQL 学习笔记
C# 切换中英文输入法
使用Visio画立方体
leetcode - 384. Scramble array
Alibaba stability fault emergency handling process
剑指offer 第 3 天字符串(简单)
Elemntui's select+tree implements the search function
515. Find Largest Value in Each Tree Row
Back test of quantitative trading - tqzfuturerenkowavestrategy
Jupyter Notebook主题字体设置及自动代码补全
Reload cuda/cudnn/pytorch
Drawing cubes with Visio
WIN10环境下配置pytorch