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

C语言——数据存储

因为:char虽然是字符类型,但是字符类型储存时候,存储字符ascii码值 ascii值是整数。...有正负数据可以存放在有符号变量中 只有正数数据可以存放在无符号变量中 浮点数家族:  构造类型:  指针类型 空类型 原码 反码 补码 计算机中整数有三种表示方法,即原码、反码和补码...三种表示方法均有符号位和数值位两部分,符号位都是用0表示“正”,用1表示“负”,而数值位 负整数三种表示方法各不相同  原码 :直接将二进制按照正负形式翻译成二进制就可以....反码:将原码符号位不变,其他位依次取反就可以得到了 补码:反码加一就是补码 对于整数来说,数据存放内存中其实存放是补码 大小端介绍 大端小端 大端(存储)模式,是指数据低位保存在内存高地址中...,而数据高位,保存在内存低地址 中; 小端(存储)模式,是指数据低位保存在内存低地址中,而数据高位,,保存在内存高地 址中

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

    C语言--数据存储

    原来,在计算机中,内存存储数据,采用是字节序大小端存储模式。 什么是大小端?...大端(存储)模式,是指数据低位保存在内存高地址中,而数据高位,保存在内存低地址 中; 小端(存储)模式,是指数据低位保存在内存低地址中,而数据高位,,保存在内存高地 址中。...但是在C语言中除了8 bitchar之外,还有16 bitshort型,32 bitlong型(要看具体编译器),另外,对于位数大于8位处理器,例如16位或者32位处理器,由于寄存器宽度大于一个字节...我们常用 X86 结构是小端模式,而 KEIL C51 则为大端模式。很多ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。 2.3 练习题 3....、浮点型在内存中存储 通过上面,我们知道,整数在计算机里面的存储方式是根据二进制原、反、补码来存储和使用。那么,浮点数,是否也是用原反补呢?如果是用原反补,那么它小数点是什么样形式?

    1.7K20

    C语言 | 变量存储方式

    在编程方面有着天赋异禀的人毕竟是少数,我们大多数人想要从C语言小白进阶到高手,需要经历是日积月累学习。 那么如何学习呢?当然是每天都练习一道C语言题目!! ? 作者 闫小林 白天搬砖,晚上做梦。...C语言动态存储方式与静态存储方式 静态存储方式是指在程序运行期间由系统分配固定存储空间方式;动态存储方式是在程序运行期间根据需要进行动态分配存储空间方式。...内存中供用户使用存储空间可以分为3部分, 程序区 静态存储区 动态存储区 全局变量全部存放在静态存储区中,在程序开始执行时给全局变量分配存储区,程序执行完毕就释放。...在C语言中,每一个变量和函数都有两个属性: 数据类型 数据存储类别。 C语言存储类别包括4种: 自动(auto) 静态(static) 寄存器(register) 外部(extern)。...C语言局部变量存储类别 自动变量(auto变量) 函数中局部变量,如果不专门声明static存储类别,都是动态地分配存储空间,数据存储在动态存储区中。自动变量用关键字auto做存储类别声明。

    1.5K60

    C语言 | 变量存储方式

    C语言动态存储方式与静态存储方式 静态存储方式是指在程序运行期间由系统分配固定存储空间方式;动态存储方式是在程序运行期间根据需要进行动态分配存储空间方式。...内存中供用户使用存储空间可以分为3部分, 程序区 静态存储区 动态存储区 全局变量全部存放在静态存储区中,在程序开始执行时给全局变量分配存储区,程序执行完毕就释放。...在C语言中,每一个变量和函数都有两个属性: 数据类型 数据存储类别。 C语言存储类别包括4种: 自动(auto) 静态(static) 寄存器(register) 外部(extern)。...C语言局部变量存储类别 自动变量(auto变量) 函数中局部变量,如果不专门声明static存储类别,都是动态地分配存储空间,数据存储在动态存储区中。自动变量用关键字auto做存储类别声明。...100道C语言源码案例请去公众号:C语言入门到精通

    2.2K40

    初识C语言·数据存储

    1 整数在内存中存储 前面讲到,整数在计算机中存储是以补码形式存储,其中正数和负数也有些许差别,正数三码相同,负数就不相同了,那么这里就涉及原码反码补码。...3 整数存储练习题 代码1: 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结果都是-1,那么,unsigned char类型没有符号位,全是数值位,截断之后是11111111,提升之后是32个1,32个1也就是2^8 -  1,所以c是255。...根据IEEE 754规定,对于32位浮点数,最高位存储符号位S,接着8位存储指数E,剩下23位存储有效数字M, 对于64位浮点数·,最高位存储符号位S,接着11位存储指数E,剩下52位存储有效数字

    7010

    C语言之数据存储

    C语言中数据在内存中存储 文章目录 C语言中数据在内存中存储 1.数据类型介绍 2.整形在内存中存储 2.1原码,反码,补码 2.2大小端字节序 2.3试题练习 3.浮点数在内存中存储...3.1.浮点数在计算机内部表示方法 3.2.浮点数存储规则 3.3.一个练习题 写在最后 1.数据类型介绍 C语言中具体由哪些数据结构: ps: 1.这里需要提醒大家就是其实char也是整形家族...但是在C语言中除了8 bitchar之外,还有16 bitshort型,32 bitlong型(要看具体编译器)。...练习:百度2015年系统工程师笔试题 简述大小端字节序概念,并设计一个程序来判断当前机器字节序。...C语言标准规定: 1.当一个数超过该类型数据所能存储最大值就发生截断。如八个比特位char存储32个比特位int时只存储最后面的八个比特位。

    1.5K00

    C语言详解(数据存储

    1、大小端字节序和字节序判断 在 C语言(操作符)1 中,我们介绍了整数在内存中存储,但是我们只介绍了整数存储形式,并没有介绍整数是如何存储,那本节我们就来探讨一下整数在内存中究竟是怎么存储...如果我们想知道当前机器使用是哪种存储方式,可以写一个简单判断小程序来实现。...(其实我们在C语言(操作符)2中表达式求值部分已经学习过)我们来分析一下: 我们想将整数-1存入一个字符型变量a中,整型和字符型不兼容,通过C语言(操作符)2学习我们知道要发生截断,...在C语言(操作符)2中,我们还画了这样一个图,并做了相应解释。...上面这个代码也是如此,当i为0时,0-1就变成了2^32-1,因为在unsigned int世界里没有负数,所以程序陷入了死循环。

    8010

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

    ✨作者:@平凡的人1 ✨专栏:《C语言从0到1》 ✨一句话:凡是过往,皆为序章 ✨说明: 过去无可挽回, 未来可以改变 ---- 感谢您点赞与关注,同时欢迎各位有空来访我平凡舍 --...但是在C语言中除了8 bitchar之外,还有16 bitshort型,32 bitlong型(要看具体编译器),另外,对于位数大于8位处理器,例如16位或者32位处理器,由于寄存器宽度大于一个字节...我们常用 X86 结构是小端模式,而 KEIL C51 则为大端模式。很多ARM,DSP都为小端模式。...有些ARM处理器还可以由硬件来选择是大端模式还是小端模式 那么问题又双叒叕来了: 请简述大端字节序和小端字节序概念,设计一个小程序来判断当前机器字节序 概念性东西上面说了,代码怎么设计?...("a=%d,b=%d,c=%d",a,b,c); return 0; } 想想为什么?

    64130

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

    一、数据类型详细介绍 1.c语言基本内置类型 (c语言本身就具有的类型,我们可以直接拿来使用) ? c语言类型: 1.内置类型 2. 自定义类型(构造类型) ?...首先char是字符类型,不好归类,同时字符在内存中是以Ascll码值存储,Ascll码值是整数,字符存储时候也是以整数进行存储,所以也属于整形家族   unsigned signed 怎么描述有符号无符号呢...相加结果 10000000 0000000 0000000 0000000 (c补码) 整型只能存储32bit位,前面的1舍去 c是一个整型,只能存32个bit位,所以补码就为全0 c结果为...借着这个机会,了解一下大小端知识 6.百度2015年系统工程师笔试题:   请简述大端字节序和小端字节序概念,设计一个小程序来判断当前机器字节序 #include int check_sys()...博客入口:C语言进阶(二)— 整型存放练习   好了,到此我们就知道了整型在内存中是如何存储,那么浮点型数据在内存中是如何存储? 三、浮点型在内存中存储 1.浮点数表示形式 ?

    2.1K20

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

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

    54750

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

    ASCII值存储,所以也属于整型家族 下表列出了关于标准整数类型存储大小和值范围细节: 注意,各种类型存储大小与系统位数有关,但目前通用以64位系统为主。...以下列出了32位系统与64位系统存储大小差别(windows 相同): 二.整型存储 数据在内存中以2进制形式存储,对于整数来说: 1.整数二进制有三种表示形式:原码,反码,补码。...注意:数据都是以补码形式存储,计算时也是补码之间运算,打印时按照原码打印。...三.整型提升 1.什么是整型提升: C整型算数运算总是至少以缺省整型类型精度来进行。...首先 char 类型到底是 signed char 还是 unsigned char ,C语言标准并没有规定,这取决于编译器 1.

    25610

    C语言(顶级黑客c程序

    作为世界最牛逼黑客之一,Linus Torvalds特立独行就跟他软件Linux一样受人瞩目,那你想知道Linux创始人Linus Torvalds是怎么写C语言程序吗?一起来感受下。...一个对程序吹毛求疵到无以复加家伙,一个纯粹代码洁癖重度患者,一个极度自恋狂,一个极不喜欢UI界面而追求极致命令操作理想主义者。这些都是Torvalds身上标签。...但不管你贴多少标签,在这些褒义贬义形容词背后,是一个真真切切对编程有偏执狂人。这位神一般开源先驱是怎么写代码呢?对我们C语言初学者而言,更有趣问题是,他是怎么写if……else呢??...程序好像永远只处理一种普适情况,这就是完美的有品位代码。 提示一下,上面的indirect是一个二级指针,指向链表中指针。...在内核中,Torvalds 代码永远是那么光芒璀璨,引人入胜!墙裂建议C语言差不多同学走入Linux世界,阅读一下世界顶级黑客大牛是怎么写程序

    4.2K50

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

    整数在内存中存储 整数存储: 整数二进制表示方法有三种:原码、反码和补码。...3.1 什么是大小端字节序 大端字节序:将一个数值最低位字节内容存储到高位地址,高位字节序内容存储到低地址处。...这是因为在计算机系统中,我们是以字节为单位,每个地址单元都对应着一个字节,一个字节为8 bit 位,但是在C语言中除了8 bit char 之外,还有16 bit short 型,32 bit...我们常用 X86 结构是小端模式,而KEIL C51 则为大端模式。很多ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。...3.3 写程序来判断当前机器字节序 设计⼀个程序来判断当前机器字节序,在大厂笔试中就有这道题目。 那我们该怎么写呢?

    15610

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

    前言 本篇博客实际上不怎么涉及到C语言知识,但要想将C语言掌握好,还必须得总结一下, 话不多说,进入正题,让我们一起来看看数据在内存中如何存储 个人主页:小张同学zkf 若有问题 评论区见...字节序——是以字节为单位,来讨论存储顺序 其实超过一个字节数据在内存中存储时候,就有存储顺序问题,按照不同存储顺序,我们分为大端字节序存储和小端字节序存储,下面是具体概念: 大端(存储)...这是因为在计算机系统中,我们是以字节为单位,每个地址单元都对应着一个字节,一个字节为8bit位,但是在C语言中除了8bitchar之外,还有16bit short 型,32bitlong型(要看具体编译器...最后看一下c,c是无符号类型,那它储存8个1没有符号位,都是数值位,由于是无符号位,%d为有符号int整形,所以整形提升高位直接补0,此时最高位是零,是正数,此时原码反码补码相同,得到结果为255...,数据在内存中如何存储,方便我们以后C语言学习 OK感谢观看!

    11610

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

    1.c语言默认数字是int型也就是32比特位 2....%d是打印int型,也就是输出有符号十进制数字,%u是打印unsigned int,也就是输出无符号十进制整数 3.整型提升是c程序设计语言一项规定,在表达式进行计算时,所有的整型首先要提升为...("a=%d,b=%d,c=%d",a,b,c); return 0; } 储存: -1补码为全1,当发生截断后存储在变量abc中内存形式均为11111111,但打印是int型十进制数字...1减1(补码)形式,被继续当作原码处理并输出,那么程序会一直走下去 32个比特位,从4294967295开始走,输出一次-1一下,把程序都干死了走 6. int main() { char...输出结果:我们其实可以知道,无论i数值为多少,它永远都在0到255这个循环里面,那么for循环判断条件就永远成立,所以这个循环就会一直进行下去,自然程序输出结果为死循环 三:浮点型在内存中存储

    1K20

    C语言:数据在内存中存储

    整数在内存中存储 整数在内存中存储是二进制 整数2进制表⽰⽅法有三种,即原码、反码和补码 原码取反得到反码,加1得到补码。...= -1; //%d-打印有符号整数 //%u-打印无符号整数 //打印是原码 printf("a = %d b = %d c = %d", a, b, c); } c为什么是255...int main() { char a = -1; signed char b = -1; unsigned char c = -1; //c-1原码1000 0000 0000 0000...IEEE 754规定: 对于32位浮点数,最⾼1位存储符号位S,接着8位存储指数E,剩下23位存储有效数字M?...比特就业课 对于64位浮点数,最⾼1位存储符号位S,接着11位存储指数E,剩下52位存储有效数字M double练习 浮点数存过程 IEEE 754对有效数字M和指数E,还有⼀些特别规定。

    9310
    领券