C语言——二周目——数据在内存中的存储

news2025/3/13 2:33:40

目录

一、整数的存储方式

二、浮点数的存储方式


一、整数的存储方式

        因为CPU只有加法器,所以对于整型来说,数据在内存中通常采用补码的方式进行储存。

        在这里复习一下原码、反码、补码。

正数和无符号数的原码、反码、补码相同;

负数的原码是把数字按二进制直接翻译,反码是原码除符号位按位取反,补码是反码+1 。

int a = 20;

// 0000 0000 0000 0000 0000 0000 0001 0100 —— 原码

// 0000 0000 0000 0000 0000 0000 0001 0100 —— 反码

// 0000 0000 0000 0000 0000 0000 0001 0100 —— 补码

// 0x00 00 00 14

int b = -10;

// 1000 0000 0000 0000 0000 0000 0000 1010 —— 原码

// 1111 1111 1111 1111 1111 1111 1111 0101 —— 反码

// 1111 1111 1111 1111 1111 1111 1111 0110 —— 补码

// 0x ff ff ff f6

        我们所熟知的int类型通常在内存中占用4个字节的空间,而short类型占用2个字节,char类型则使用1个字节的空间。所以我们敏锐的察觉到,既然空间有限,那么总会有空间存不下的数字,这时候怎么办呢?

        这便引出了溢出的问题。我们以char类型为例子,来讨论一下数字变化规律。

 我们从中可以发现一些比较实用的规律:

        ①-1的补码二进制位全为1;

        ②对于一个有符号整数家族的类型,其所能表示的最小的负数为符号位取1,其余位取0;

        ③溢出发生在所能存储的最大值变为所能存储的最小值;

二、浮点数的存储方式

任意一个二进制浮点数可以表示为该形式: (-1)^S * M * 2^E

(-1)^S 表示符号位,S=0为正数,S=1为负数;

M表示有效数字;

2^E表示指数位。

例如,5.0二进制是101.0,相当于1.01 * 2^2。得到S=0,M=1.01,E=2 。 

        以上便是二进制的科学计数法的表示,可以类比我们熟悉的十进制的科学计数法来学习。

对于32位的浮点数(float),最高的1位是符号位S紧接着8位是指数E剩下的23位是有效数字M

对于64位的浮点数(double),最高的1位是符号位S紧接着11位是指数E剩下的52位是有效数字M。其内部存储方式与float大同小异,区别在于double的偏置值位1023,即储存E时要在实际指数的基础上加1023.

小结一下:

1)M一定为1.xxxxxx,所以默认舍去1,只保留xxxxxx这一部分。如1.01只保存01;

2)E有可能为负数,所以存入E时会加上一个中间数,E为8位时中间数为127,E为11位时中间数位1023。如2^10,保存为32为浮点数时,保存为10+127=137,即1000 1001。

3)E从内存中取出分为三种情况:

        ①E不全为0或不全为1:E减去127(或1023),在M前加上第一位的1。

        ②E全为0:此时E的真实值为-127(-1023),有效数字M不再加上第一位的1,而是还原为0.xxxxxx的小数,以表示+-0或接近于0很小的数字。

        ③E全为1:此时如果有效数字M全为0,表示+-无穷大。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1104138.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

考察软件开发公司的能力

当公司需要与软件外包公司合作时需要考察软件开发公司的能力和水平,这会涉及到很多方面的因素。需要通过综合考察和了解软件开发公司的能力和水平,选择合适的合作伙伴,确保项目的成功交付。下面分享一些关键步骤和方法,希望对大家…

【JVM】JVM的垃圾回收机制

JVM的垃圾回收机制 对象死亡判断方法引用计数算法可达性分析算法 垃圾回收算法标记清除法复制算法标记整理算法分代算法 Java运行时内存的各个区域,对于程序计数器,虚拟机栈,本地方法栈这三个部分区域而言,其生命周期与相关线程有关,随线程而生,随线程而灭,并且这三个区域的内存…

Excel冻结窗格

1、冻结表格首行 点击菜单栏中的“视图”,选择“窗口”选项卡中的“冻结窗格”下的小三角,再选择“冻结首行”; 2.冻结表格首列 点击菜单栏中的“视图”,选择“窗口”选项卡中的“冻结窗格”下的小三角,再选择“冻结…

图扑智慧仓储数据可视化监控平台

随着市场竞争加剧和市场需求的不断提高,企业亟需更加高效、智能且可靠的仓储物流管理方式,以提升企业的物流效率,减少其输出成本,有效应对市场上的变化和挑战。 图扑软件应用自研 HT for Web 产品搭建的 2D 智慧仓储可视化平台&a…

【轻松搞定】Edge 或 Google 无法上网问题

目录 前言 一、解决 Edge 无法上网的问题 1.1 键盘按下 WIN R 或 右键开始标志,启动运行 1.2 输入 regedit 进入注册表管理 1.3 打开到 \HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft 位置下新建项 Edge 1.4 右键 Edge 新建 DWORD (32) 文件&#xff0c…

<FPGA>好的编码风格(1)--尽量避免组合逻辑环路(Combinational Loops)

什么是组合逻辑环路? 组合逻辑环路(Combinational Loops):指组合逻辑的输出信号不经过任何时序逻辑(FF等),而是直接反馈到输入节点,从而构成的电路环路。 此外,如果直接将…

【开源分享】基于Html开发的房贷计算器,模仿新浪财经

房贷计算器是一种房贷计算的在线计算Web应用,按用户选择的贷款类型、贷款金额、期限、利率可计算得出每月月供参考、支付利息、还款总额这些信息。本文模仿新浪财经开发的房贷计算器。 作品预览 https://fangdai.gitapp.cn 源码地址 https://github.com/geeeeeee…

Qt5.12.12构建64位QMYSQL数据库驱动“driver not loaded”

在调用QSqlDatabase::open()时,会报错:“driver not loaded” 原因实际上是mysql 的驱动 qsqlmysql.dll 没有成功加载。 所以本篇文章将详细介绍一下:Qt5.12.12如何构建64位QMYSQL数据库驱动。 执行 写在最前,以下出现的文件路径为我自己电脑安装的路径,可根据自己的路…

vim快捷指令

普通模式—>插入模式 i:插入到当前光标的前面(insert) a:插入到光标的后面(append) o:插入到下一行 I:插入到行首 A:插入到行尾 O:插入到前一行 H:行首 L:页的最后一行的行首 W:光标跳到下一个单词词首 b:上一个单…

广州华锐互动:VR模拟高楼层建筑应急逃生,提供身临其境的虚拟体验

随着城市化进程的不断加速,高层建筑越来越多地出现在我们的生活中。然而,高层建筑的安全问题也日益凸显。一旦发生火灾、地震等突发事件,如何迅速、安全地逃离高楼成为了人们关注的焦点。近年来,虚拟现实(VR&#xff0…

JUC并发编程——ForkJoin与异步回调

ForkJoin (分支合并) 什么是ForkJoin ForkJoin在JDK1.7出现 ,并行执行任务,在大数据量下,能够提高效率 讯飞星火提供的说法: Forkjoin是一种并行计算的算法,用于将一个大任务分解为多个小任务…

【PSO-RFR预测】基于粒子群算法优化随机森林回归预测研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

MinIO (三) 使用Webhook实时同步文件

前言 使用MinIO的过程中,我们这里遇到个需求,系统需要预览3D文件,前端操作,用浏览3D文件的工具打开3D文件的目录即可实现在线预览功能,这个时候问题来了,MinIO上传文件后进行了编译,如下图 这个…

ardupilot开发 --- 外设适配器、拓展外设、AP_Periph、DroneCAN 、UAVCAN 篇

什么是外设适配器,为什么要拓展外设? 飞控的外设接口有限,如串口只有8个,I^2C只有一个,CAN口只有一个,这些接口数量如果不能满足预期的传感器数量,那么就需要对这些接口进行拓展,外…

ELK日志分析系统的详细介绍与部署

文章目录 1. ELK的概述1.1 简介1.2 使用ELK的理由1.3 ELK的主要组件1.3.1 Elasticsearch1.3.2 Kibana1.3.3 Logstash1.3.3.1 简介1.3.3.2 Logstash常用相关命令选项 1.3.3.3 Logstash 的输入和输出流1.3.4 Logstash的相关配置文件 1.3.4 Filebeat1.3.4.1 简介1.3.4.2 filebeat …

【vue2高德地图api】01-创建应用,获取key值

系列文章目录 【vue2高德地图api】视频效果(手机端)先看这里 文章目录 系列文章目录前言创建key(2个)1.1进入控制台1.2进入应用1.3 创建应用1.4输入名称和类型2.1 添加key2.2 选择对应信息2.3 创建js key和服务端 key 总结 前言 …

数仓建设(一)

想了想,我们的数仓的建设是基于大数据平台进行的,中间也经历了比较曲折的过程。 每个行业都有自身的业务区别,不过很多还是比较相通的。 本文将全面讲解数仓建设规范,从数据模型规范,到数仓公共规范,数仓各…

vue3实现el-card的body的样式穿透

:deep(.el-card .el-card__body){padding-top:20px!important; }改el-card的body 将内容的padding变成上下左右都是20px el-card默认是上面为15px,其他左右下都是20px 详解源码vue3的样式穿透scope-CSDN博客

Linux系统中配置系统设置

在Linux系统中配置系统设置->网络设置代理的详细教程如下: 首先,确保您已经安装了NetworkManager和nmtui。在终端中输入以下命令: sudo apt-get update sudo apt-get install network-manager nmtui 打开系统设置。在桌面上点击“设置”…

多媒体应用设计师 第8章 多媒体应用的新技术

1.信息可视化技术 1.1.信息可视化的定义 信息可视化:将广泛存在的非具体数据以能满足人机交互的方式表达出使信息接收员可以方便的分析数据,找出数据规律,完成对信息的处理。信息可视化的两大基础:认知心理学和图像设计。 可视化方式分为:一维&#xf…