- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章关于C语言中数据在内存中的存储详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
1. 数据类型详细介绍 。
2. 整形在内存中的存储:原码、反码、补码 。
3. 大小端字节序介绍及判断 。
4. 浮点型在内存中的存储解析 。
char unsigned char signed char short unsigned short [int] signed short [int] int unsigned int signed int long unsigned long [int] signed long [int] 。
float double 。
数组类型 结构体类型 struct 枚举类型 enum 联合类型 union 。
int pi; char pc; float pf; void pv,
void 表示空类型(无类型) 通常应用于函数的返回类型、函数的参数、指针类型 。
计算机中的有符号数有三种表示方法,即原码、反码和补码。 三种表示方法均有符号位和数值位两部分,符号位都是用0表示“正”,用1表示“负”,而数值位 三种表示方法各不相同。 原码: 直接将二进制按照正负数的形式翻译成二进制就可以。 反码: 将原码的符号位不变,其他位依次按位取反就可以得到了.
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
|
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int
main()
{
int
a = 20;
//00000000 00000000 00000000 00010100 20的原码、反码、补码相同
int
b = -10;
//10000000 00000000 00000000 00001010 10的原码
printf
(
"%d\n"
, a + b);
//11111111 11111111 11111111 11110101 10的反码
return
0;
//11111111 11111111 11111111 11110110 10的补码
}
//00000000 00000000 00000000 00010100 20的补码
//100000000 00000000 00000000 00001010 两者相加,因为int只有32位丢掉最前面的
|
大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中; 小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中.
为什么会有大小端模式之分呢?这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如果将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。 例如一个 16bit 的 short 型 x ,在内存中的地址为 0x0010 , x 的值为 0x1122 ,那么 0x11 为高字节, 0x22为低字节。对于大端模式,就将 0x11 放在低地址中,即 0x0010 中, 0x22 放在高地址中,即 0x0011 中。小端模式,刚好相反。我们常用的 X86 结构是小端模式,而 KEIL C51 则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式.
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int
FindKey(
int
i)
{
return
*(
char
*)&i;
}
int
main()
{
int
i = 1;
int
ret = FindKey(i);
if
(ret == 1)
{
printf
(
"小端!\n"
);
}
else
{
printf
(
"大端!\n"
);
}
return
0;
}
|
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
|
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int
main()
{
char
a = -1;
//10000000 00000000 00000000 000000001 -1的原码
signed
char
b = -1;
//11111111 11111111 11111111 111111110 -1的反码
unsigned
char
c = -1;
//11111111 11111111 11111111 111111111 -1的补码
printf
(
"a=%d,b=%d,c=%d"
, a, b, c);
//因为a是字符类型,所以发生截断 111111111
return
0;
//%d打印十进制,所以发生整形提升,按符号位来提升
}
//11111111 11111111 11111111 11111111 -1的补码,所以原码为-1
//对于unsigned char来说 11111111 中1不是符号位所以高位补0
//00000000 00000000 00000000 11111111 所以为正数,原、反、补相同为255
|
代码如下:
1
2
3
4
5
6
7
8
9
|
int
main()
{
char
a = -128;
//10000000 00000000 00000000 10000000 128的原码
printf
(
"%u\n"
, a);
//11111111 11111111 11111111 01111111 128的反码
}
//11111111 11111111 11111111 10000000 128的补码
//因为a是字符类型,所以发生截断 10000000 a的值
//%u是打印无符号整形,所以发成整形提升
//11111111 11111111 11111111 10000000
//%u是无符号整形,所以原码、反码、补码相同
|
代码如下:
1
2
3
4
5
6
7
8
9
|
int
main()
{
char
a = 128;
//00000000 00000000 00000000 10000000 128的原码
printf
(
"%u\n"
, a);
//01111111 11111111 11111111 01111111 128的反码
}
//01111111 11111111 11111111 10000000 128的补码
//因为a是char类型,所以发生截断 10000000 -a
//%u是打印无符号整形,所以发生整形提升,因为是char类型,所以高位是符号位
//11111111 11111111 11111111 100000000
//%u是无符号整形,所以原码、反码、补码相同
|
代码如下:
1
2
3
4
5
6
7
8
9
|
int
main()
{
int
i = -20;
//10000000 00000000 00000000 00010100 -20的原码
unsigned
int
j = 10;
//11111111 11111111 11111111 11101011 -20的反码
printf
(
"%d\n"
, i + j);
//11111111 11111111 11111111 11101100 -20的补码
}
//00000000 00000000 00000000 00001010 10的原码、反码、补码
//11111111 11111111 11111111 11110110 相加为补码
//11111111 11111111 11111111 11110101 反码
//10000000 00000000 00000000 00001010 补码 为-10
|
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<Windows.h>
int
main()
{
unsigned
int
i = 0;
//此时打印完9 8 7 6 5 4 3 2 1 0减减为-1是无符号在内存中补码是全部为1,i恒大于0
for
(i = 9; i >= 0; i--)
{
printf
(
"%u \n"
, i);
Sleep(1000);
}
return
0;
}
|
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<Windows.h>
int
main()
{
unsigned
int
i = 0;
//此时打印完9 8 7 6 5 4 3 2 1 0减减为-1是无符号在内存中补码是全部为1,i恒大于0
for
(i = 9; i >= 0; i--)
{
printf
(
"%u \n"
, i);
Sleep(1000);
}
return
0;
}
|
代码如下:
1
2
3
4
5
6
7
8
9
|
unsigned
char
i = 0;
int
main()
{
for
(i = 0; i <= 255; i++)
//死循环的打印bit,因为unsigned char取值范围是0-255,所以for循环永远成立
{
printf
(
"bit\n"
);
}
return
0;
}
|
根据国际标准IEEE(电气和电子工程协会) 754,任意一个二进制浮点数V可以表示成下面的形式: 1.(-1)^S * M * 2^E (-1)^s表示符号位,当s=0,V为正数;当s=1,V为负数。 2.M表示有效数字,大于等于1,小于2。 3.2^E表示指数位。 举例来说: 十进制的5.0,写成二进制是 101.0 ,相当于 1.01×2^2 。 那么,按照上面V的格式,可以得出s=0,M=1.01,E=2。 十进制的-5.0,写成二进制是 -101.0 ,相当于 -1.01×2^2 。那么,s=1,M=1.01,E=2。 IEEE 754规定: 对于32位的浮点数,最高的1位是符号位s,接着的8位是指数E,剩下的23位为有效数字M 。
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int
main()
{
int
n = 9;
float
* pFloat = (
float
*)&n;
printf
(
"n的值为:%d\n"
, n);
printf
(
"*pFloat的值为:%f\n"
, *pFloat);
*pFloat = 9.0;
printf
(
"num的值为:%d\n"
, n);
printf
(
"*pFloat的值为:%f\n"
, *pFloat);
return
0;
}
|
以上就是今天要讲的内容,本文仅仅简单介绍了数据整形和浮点型在内存中的存储,了解这个更能令我们了解数据怎么在内存中存储。另外,如果上述有任何问题,请懂哥指教,不过没关系,主要是自己能坚持,更希望有一起学习的同学可以帮我指正,但是如果可以请温柔一点跟我讲,爱与和平是永远的主题,爱各位了.
到此这篇关于关于C语言中数据在内存中存储的文章就介绍到这了,更多相关C语言数据在内存的存储内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://blog.csdn.net/qq_44918090/article/details/115585125 。
最后此篇关于关于C语言中数据在内存中的存储详解的文章就讲到这里了,如果你想了解更多关于关于C语言中数据在内存中的存储详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
初学者 android 问题。好的,我已经成功写入文件。例如。 //获取文件名 String filename = getResources().getString(R.string.filename
我已经将相同的图像保存到/data/data/mypackage/img/中,现在我想显示这个全屏,我曾尝试使用 ACTION_VIEW 来显示 android 标准程序,但它不是从/data/dat
我正在使用Xcode 9,Swift 4。 我正在尝试使用以下代码从URL在ImageView中显示图像: func getImageFromUrl(sourceUrl: String) -> UII
我的 Ubuntu 安装 genymotion 有问题。主要是我无法调试我的数据库,因为通过 eclipse 中的 DBMS 和 shell 中的 adb 我无法查看/data/文件夹的内容。没有显示
我正在尝试用 PHP 发布一些 JSON 数据。但是出了点问题。 这是我的 html -- {% for x in sets %}
我观察到两种方法的结果不同。为什么是这样?我知道 lm 上发生了什么,但无法弄清楚 tslm 上发生了什么。 > library(forecast) > set.seed(2) > tts lm(t
我不确定为什么会这样!我有一个由 spring data elasticsearch 和 spring data jpa 使用的类,但是当我尝试运行我的应用程序时出现错误。 Error creatin
在 this vega 图表,如果我下载并转换 flare-dependencies.json使用以下 jq 到 csv命令, jq -r '(map(keys) | add | unique) as
我正在提交一个项目,我必须在其中创建一个带有表的 mysql 数据库。一切都在我这边进行,所以我只想检查如何将我所有的压缩文件发送给使用不同计算机的人。基本上,我如何为另一台计算机创建我的数据库文件,
我有一个应用程序可以将文本文件写入内部存储。我想仔细看看我的电脑。 我运行了 Toast.makeText 来显示路径,它说:/数据/数据/我的包 但是当我转到 Android Studio 的 An
我喜欢使用 Genymotion 模拟器以如此出色的速度加载 Android。它有非常好的速度,但仍然有一些不稳定的性能。 如何从 Eclipse 中的文件资源管理器访问 Genymotion 模拟器
我需要更改 Silverlight 中文本框的格式。数据通过 MVVM 绑定(bind)。 例如,有一个 int 属性,我将 1 添加到 setter 中的值并调用 OnPropertyChanged
我想向 Youtube Data API 提出请求,但我不需要访问任何用户信息。我只想浏览公共(public)视频并根据搜索词显示视频。 我可以在未经授权的情况下这样做吗? 最佳答案 YouTube
我已经设置了一个 Twilio 应用程序,我想向人们发送更新,但我不想回复单个文本。我只是想让他们在有问题时打电话。我一切正常,但我想在发送文本时显示传入文本,以确保我不会错过任何问题。我正在使用 p
我有一个带有表单的网站(目前它是纯 HTML,但我们正在切换到 JQuery)。流程是这样的: 接受用户的输入 --- 5 个整数 通过 REST 调用网络服务 在服务器端运行一些计算...并生成一个
假设我们有一个名为 configuration.js 的文件,当我们查看内部时,我们会看到: 'use strict'; var profile = { "project": "%Projec
这部分是对 Previous Question 的扩展我的: 我现在可以从我的 CI Controller 成功返回 JSON 数据,它返回: {"results":[{"id":"1","Sourc
有什么有效的方法可以删除 ios 中 CBL 的所有文档存储?我对此有疑问,或者,如果有人知道如何从本质上使该应用程序像刚刚安装一样,那也会非常有帮助。我们正在努力确保我们的注销实际上将应用程序设置为
我有一个 Rails 应用程序,它与其他 Rails 应用程序通信以进行数据插入。我使用 jQuery $.post 方法进行数据插入。对于插入,我的其他 Rails 应用程序显示 200 OK。但在
我正在为服务于发布请求的 API 调用运行单元测试。我正在传递请求正文,并且必须将响应作为帐户数据返回。但我只收到断言错误 注意:数据是从 Azure 中获取的 spec.js const accou
我是一名优秀的程序员,十分优秀!