首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C语言--数据存储

目录 1、数据类型介绍 1.1、类型的基本归类 2、整形在内存中的存储 2.1、原码、反码、补码 2.2 大小端 2.3 练习题 3....、浮点型在内存中的存储 3.1 一个例子 3.2 浮点数存储规则 ---- 1.数据类型介绍 基本的内置类型: char   字符数据类型                                                                                                                         ...原来,在计算机中,内存存储数据,采用的是字节序的大小端存储模式。 什么是大小端?...大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址 中; 小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地 址中。...我们常用的 X86 结构是小端模式,而 KEIL C51 则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。 2.3 练习题 3.

1.7K20

C语言】数据存储

一、整形在内存中的存储 1....对于整形来说:数据存放内存中其实存放的是补码;在计算时,需要将整数的原码表示出来,若是正数,原反补相同,即可计算;若是负数,需将负数的原码表示出来,再转换为补码,再进行计算,计算完的数值仍然是补码,还需转换为原码才是最后的结果...大小端的存储模式 大端(存储)模式:是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中; eg:0x11223344 小端(存储)模式:是指数据的低位保存在内存的低地址中,而数据的高位...-1; printf("a=%d,b=%d,c=%d",a,b,c); return 0; } 分析: 10000000 00000000 00000000 00000001...= 9.0时,9.0以浮点数的存储模式存到内存中,当以%d的形式打印时,会以整型数的解读方式解读9.0浮点数存储模式的二进制,所以是结果是1,091,567,616 int main()

11910
您找到你想要的搜索结果了吗?
是的
没有找到

C语言——数据存储

目录 数据类型介绍 整型家族 浮点数家族:  构造类型:  指针类型 空类型 原码 反码 补码 大小端介绍 大端小端 数据类型介绍 相信大家应该已经了解了基本的数据类型吧 整型家族 char 为什么归根到...因为:char虽然是字符类型,但是字符类型储存的时候,存储的字符的ascii码值 ascii值是整数。...有正负的数据可以存放在有符号的变量中 只有正数的数据可以存放在无符号的变量中 浮点数家族:  构造类型:  指针类型 空类型 原码 反码 补码 计算机中的整数有三种表示方法,即原码、反码和补码...反码:将原码的的符号位不变,其他位依次取反就可以得到了 补码:反码加一就是补码 对于整数来说,数据存放内存中其实存放的是补码 大小端介绍 大端小端 大端(存储)模式,是指数据的低位保存在内存的高地址中...,而数据的高位,保存在内存的低地址 中; 小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地 址中

1.4K10

C语言之数据存储

C语言中数据在内存中的存储 文章目录 C语言中数据在内存中的存储 1.数据类型的介绍 2.整形在内存中的存储 2.1原码,反码,补码 2.2大小端字节序 2.3试题练习 3.浮点数在内存中的存储...3.1.浮点数在计算机内部的表示方法 3.2.浮点数的存储规则 3.3.一个练习题 写在最后 1.数据类型的介绍 C语言中具体由哪些数据结构: ps: 1.这里需要提醒大家的就是其实char也是整形家族的...---- 2.整形在内存中的存储 我们知道一个变量的创建是要在内存中开辟空间的,空间的大小是根据不同的类型决定的。那我们接下来谈谈数据在所开辟的内存中到底是如何存储的。...大小端指的是数据以字节为单位在内存中的存储顺序。 大端存储模式:把数据的低位保存在内存中的高地址中,而数据的高位保存在内存的低地址中。...C语言标准规定: 1.当一个数超过该类型数据所能存储的最大值就发生截断。如八个比特位的char存储32个比特位的int时只存储最后面的八个比特位。

1.4K00

C语言进阶(一)---数据存储

一、数据类型详细介绍 1.c语言的基本内置类型 (c语言本身就具有的类型,我们可以直接拿来使用) ? c语言的类型: 1.内置类型 2. 自定义类型(构造类型) ?...接下来重点解释整型和浮点型在内存中的存储 二、整型在内存中的存储   一个变量的创建是要在内存中开辟空间的,空间的大小是根据不同的类型决定的。 1. 数据在所开辟内存中是如何储存的呢?...通过调试,我们得知了a,b在内存中存储的内容,那么a,b是如何转换成这样的数据呢? ? 将a,b进行二进制转换,内存中存储的是补码,计算a,b的补码 ?   ...) 整型只能存储32bit位,前面的1舍去 c是一个整型,只能存32个bit位,所以补码就为全0 c的结果为0;结果正确!!!...博客入口:C语言进阶(二)— 整型存放练习   好了,到此我们就知道了整型在内存中是如何存储的,那么浮点型的数据在内存中是如何存储的? 三、浮点型在内存中的存储 1.浮点数表示的形式 ?

2.1K20

C语言】探索数据存储(上篇)

-- 文章目录 @[toc] ✍前言 数据类型 数据类型的基本分类 整形在内存中的存储 原码、反码、补码 大小端介绍 练习 结语 ✍前言 HelloHello,大家好,今天我们来一起来探索数据存储问题...数据存储这块内容还是有点难度的。但是学起来是真的有趣,让我们一起来看一看把!...整形在内存中的存储 计算机中的整数有三种2进制表示方法,即原码、反码和补码 我们之前讲过一个变量的创建是要在内存中开辟空间的。空间的大小是根据不同的类型而决定的。那数据在所开辟内存中到底是如何存储的?...大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中; 小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中。...("a=%d,b=%d,c=%d",a,b,c); return 0; } 想想为什么?

62530

C数据在内存中的存储

本章重点 数据类型详细介绍 整形在内存中的存储:原码、反码、补码 大小端字节序介绍及判断 浮点型在内存中的存储解析 1....数据类型介绍 char //字符数据类型 short //短整型 int //整形 long //长整型 long long //更长的整形 float //单精度浮点数 double /...整形在内存中的存储 我们之前说过一个变量的创建是要在内存中开辟空间的。空间的大小是根据不同的类型而决定的 那接下来我们谈谈数据在所开辟内存中到底是如何存储的?...,就有了存储顺序的问题,这里就规定了两种存储方式 什么大端小端: 大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中; 小端(存储)模式,是指数据的低位保存在内存的低地址中...,而数据的高位,,保存在内存的高地址中。

19420

C语言】探索数据存储(下篇)

✨作者:@平凡的人1 ✨专栏:《C语言从0到1》 ✨一句话:凡是过往,皆为序章 ✨说明: 过去无可挽回, 未来可以改变 ---- 感谢您的点赞与关注,同时欢迎各位有空来访我的平凡舍 --...-- 大家好呀,前面我们了解了数据类型,数据类型的基本分类以及整型在内存中的存储还有了大小端的存储。...现在我们来开始进入今天的重要内容:《 浮点型在内存中的存储》。下面让我们来一探究竟,浮点型在内存中是如何存储的。...下面我们一起来看看是怎么存储的 浮点数存储规则 详细解读: 根据国际标准IEEE(电气和电子工程协会) 754,任意一个二进制浮点数V可以表示成下面的形式: (-1)^S * M * 2E (-1)S表示符号位...pFloat = 9.0; 通过计算器计算出结果: 这也就是num的值了 我们看看最后一个值:以浮点数形式放,再以浮点数打印,结果自然是9.0000000 结语 好的,关于数据存储的内容这块内容我们到这里结束了

53050

C语言进阶:整型数据存储

long[int] signed long[int] char : unsigned char signed char 因为char 类型的数据是通过ASCII值存储的,所以也属于整型家族 下表列出了关于标准整数类型的存储大小和值范围的细节...以下列出了32位系统与64位系统的存储大小的差别(windows 相同): 二.整型的存储 数据在内存中以2进制的形式存储,对于整数来说: 1.整数的二进制有三种表示形式:原码,反码,补码。...注意:数据都是以补码的形式存储的,计算时也是补码之间的运算,打印时按照原码打印。...三.整型提升 1.什么是整型提升: C的整型算数运算总是至少以缺省整型类型的精度来进行的。...-1; printf("a=%d,b=%d,c=%d\n",a,b,c); return 0; } 正解:a=-1,b=-1,c=255 a 和 b 很好理解,问题就是c,我们利用上面的巧记口诀

16710

C数据存储】整型在内存中的存储(进阶版)

2-1二进制和十六进制 数据在内存中是以2进制存储,VS在展示的时候是以16进制展示的 一个字节占8个二进制位,等价也等于2个十六进制位 调试->窗口->内存->&a如何使用vs在调试时查看内存...这也类似我们的大小端字节序 为什么有大小端字节序 由上面数据以二进制补码的形式存储在内存中,如果现有一个十六进制数0x112223344,我们知道电脑内存被划分为一个个聂村单元,每一个内存单元就是一个字节...,那么我们还得再细分这个0x11223344这个数,从字节的角度考虑这个数是怎么存储的,即是数据的每一个字节究竟是怎么存储的,这也就是大小端存储存在的理由了。...对于他我们可以以11223344存,也可以44332211这样存,甚至可以31231424这末离谱地存,我们虽然平时看不到这些数据,但是在需要查看内存的时候,为了方便阅读,普遍流行的方式就是大小端存储。..."小端"); } return 0; } 二进制+大小端=整型数据在内存中的存储 4.相关笔试题 4-1 猜一猜打印的结果 int main() { char a = -1; signed

1.2K50

C语言】数据在内存中的存储

整数在内存中的存储 整数存储: 整数的二进制表示方法有三种:原码、反码和补码。...大小端字节序和字节序判断 当一个数值超过1个字节的时候,存储在内存中有存储的顺序问题,而内存的储存单元是1字节。...这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8 bit 位,但是在C语言中除了8 bit 的 char 之外,还有16 bit 的short 型,32 bit...因此就导致了大端存储模式和小端存储模式。...我们常用的 X86 结构是小端模式,而KEIL C51 则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。

13010

C语言】数据在内存中的存储

---- 前言 不同的数据在内存中的存储形式是不同的,而当我们掌握数据在内存中的存储形式之后,会帮助我们更加了解计算机深层工作原理 废话不多说,我们接下来直接进入正题 一:数据类型详细介绍 ##1....联合类型 union ##4.指针类型 1.数组指针 2.整型指针 3.字符指针 4.无类型指针 5.单精度浮点型指针 ………… ##5.空类型 void*p 这种类型指针可以接收任意的数据类型的地址...%d是打印int型的,也就是输出有符号的十进制数字,%u是打印unsigned int,也就是输出无符号的十进制整数 3.整型提升是c程序设计语言中的一项规定,在表达式进行计算时,所有的整型首先要提升为...("a=%d,b=%d,c=%d",a,b,c); return 0; } 储存: -1的补码为全1,当发生截断后存储在变量abc中的内存形式均为11111111,但打印的是int型的十进制数字...,要去读取他的原码,但c是无符号数字,所以他的原码,反码,补码相同,直接读取就OK了。

99220

数据在内存中的存储(c语言)

数据类型分类 数据的类型分为整型,浮点型,构造型,指针,和空类型。...这些类型决定类型使用时开辟空间的大小和看待这一内存空间的视角 1 整形类型 这里许多人可能想问为什么char放在了整形里面;其实是因为char在存数据时以ASCII形式存储,ASCII是整数,以整形存储...对于整形来说:数据存放内存中其实存放的是补码。 这是因为在计算机系统中,数值一律用补码来表示和存储。...而c则会从1111 1111变为11111111 11111111 11111111 11111111 也就是-1,所以b=256,c=0 让我们看看在内存中的存储 我们可以看到对于...这又是因为什么 大小端 大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址 中; 小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地

16210

C 数据存储详解】(1)——深度剖析整形数据在内存中的存储

float)); printf("%d\n", sizeof(double)); printf("%d\n", sizeof(long double)); return 0; } C语言规定了这么多不同的数据类型...2.类型的基本归类 下面我们对C语言中的数据类型做一个基本的归类: (1).整型家族 1.char unsigned char signed char 2.short unsigned...那接下来我们谈谈数据在所开辟内存中到底是如何存储的? 比如: int a = 20; int b = -10; 我们知道为 a 分配四个字节的空间。 那如何存储? 来了解下面的概念: 1....对于整形来说:数据存放内存中其实存放的是补码。 为什么呢? 在计算机系统中,数值一律用补码来表示和存储。...什么大端小端: 大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中; 小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中

16910

C语言——L数据在内存中的存储

对于整形来说:数据存放内存中其实存放的是补码。 为什么呢? 在计算机系统中,数值⼀律⽤补码来表⽰和存储。...1、什么是大小端 其实超过⼀个字节的数据在内存中存储的时候,就有存储顺序的问题,按照不同的存储顺序,我们分为⼤端字节序存储和⼩端字节序存储。...大端(存储)模式:是指数据的低位字节内容保存在内存的⾼地址处,⽽数据的⾼位字节内容,保存在内存的低地址处。...(低高地址方向0x11223344由小放大 这是大端) 小端(存储)模式:是指数据的低位字节内容保存在内存的低地址处,⽽数据的⾼位字节内容,保存在内存的⾼地址处。...b8个比特位中要发生截断所以只有 b = 11111111 // // unsigned char c = -1;//同a // //存储c8个比特位中要发生截断所以只有 c = 11111111

14010

C语言:数据在内存中的存储形式

也就是说,假设c1和c2是char类型,那么要先将要实现c1+c2,就需要对c1和c1进行整型提升之后进行运算,那么假设我们用char类型的c3去接收c1和c2的结果,由于char类型是一个字节,所以会发生截断...截断之后,只会保留低位的字节存储c3中!! 2.2 如何进行整体提升呢? 1. 有符号整数提升是按照变量的数据类型的符号位来提升的 2. ⽆符号整数提升,⾼位补0 2.3 如何进行截断呢?...当长字节的数据类型用短字节的数据类型进行存储时,会发生截断,截断就是通过简单地将高位丢弃,保存低位来实现 补充一条知识: C语言规定,char类型默认是否带有正负号,由当前的系统决定,也就是说char类型可能等价于...⼤端(存储)模式:是指数据的低位字节内容保存在内存的⾼地址处,⽽数据的⾼位字节内容,保存 在内存的低地址处。...在C语言中,赋值操作是不受大小端影响的。 其中截断是通过简单地将高位丢弃来实现的,而与数据存储的字节顺序无关 。

14510

C语言进阶-数据在内存中的存储

目录 前言 数据类型 C语言基本的内置类型 类型的意义 类型的基本归类 整形在内存中的存储 原码、反码、补码 意义 大小端 什么是大端小端  为什么有大端和小端 一道笔试题 练习 浮点型在内存中的存储...常见的浮点数 浮点数存储  浮点数存储规则 IEEE 754规定 特别规定 指数E从内存中取出 ---- 前言 ---- 本文主要讲解点 数据类型详细介绍 整形在内存中的存储:原码、反码、补码 大小端字节序介绍及判断...浮点型在内存中的存储解析 数据类型 ---- C语言基本的内置类型 char //字符数据类型 unsigned char //signed(有符号)/unsigned(无符号)...(共用一套法则)(不需要额外的硬件电路) 大小端 ---- 对于数据在内存存储补码时的字节排列顺序是有差异的(对于不同编译器) 什么是大端小端 大端:指数据的低位保存在内存的高地址中,而数据的高...8 bit 而C语言中除了8 bit的char之外,还有其他类型(大于8bite)以及寄存器宽度不一样 必然会涉及存储时字节安排的问题,而并没有规定,也没有科学的理由说服彼此,就有大小端之分 注:char

85930

C语言】数据类型存储、原码,反码,补码

内存是计算机中一个主要部件, 用于保存进程运行时的程序和数据,也称可执行存储器。在计算机中,内存空间一般是指主存储器空间(物理地址空间)或系统为一个用户程序分配内存空间。...大端小端介绍: 大端:存储模式是指内存中的低位保存在内存当中的高地址当中,而数据的高位,保存在内存的低地址当中。...小端:存储模式是指数据中的高位保存在内存当中的低地址当中,而数据的高位,保存在内存的高地址当中。...内存空间都是有编号的,我们都把内存的低位叫做低地址,编号大的话那么就是叫做高地址,数据是怎么样存储都是可以的,但是当返回到你的程序当中必须要是怎么样存储回来比如说你整形存储的是 11 22 44 33 ...,低字节的数据保存在内存当中的低地址处,而高字节的数据就保存在高地址处——小端 判断大端小端 用代码实现判断大端小端: 解体思路:一个数字a,存储在内存当中,假设这个a是20的话,在不知情的情况下,不知道当前是大端还是小端的存储

52530
领券