C语言整数和浮点数在内存中的存储

目录

  • 一.整数在内存中的存储
  • 二.浮点数在内存中的存储
    • 1.浮点数存的过程
    • 2.浮点数取的过程
      • 1.E不全为0或E不全为1
      • 2.E全为0
      • 3.E全为1
  • 三.浮点数的例题

一.整数在内存中的存储

整数在内存中是以二进制的补码存储的
正整数的源码 反码 补码 都一样,首位的符号位为0
负整数的三种表示形式各不相同
负整数的符号位为1
源码:直接把二进制翻译过来
反码:符号位不变,其他位按位取反
补码:反码+1
补码找回源码也是取反,加一

二.浮点数在内存中的存储

在这里插入图片描述

浮点数V,S表示符号位,S为0,V为正数,S为1,V为负数 M为有效数字,M>=1&&M<2
E为指数位.
10进制的5.5的浮点数表示为:101.1,根据国际标准I E
EE为:(-1)^0 * 1.011 * 2^2,S=0,M=1.011,E=2

举个例子:
5.5是十进制,5可以表示二进制为101,0.5必须要用浮点数的表示形式为:
在这里插入图片描述

浮点数分为:32位和64位浮点数。 32位浮点数(float):第一位表示符号位S,接着的8位表示的指数位E,最后的23位表示的有效数字M

在这里插入图片描述

64位浮点数(double):第一位是符号位S,接着的11位是指数E,52位是有效数M

在这里插入图片描述

1.浮点数存的过程

存入内存中
对于M

根据IEEE对有效数字M和指数E有些特殊的规定 对于M,M的表示形式为:1.XXX,XXX为小数部分
比如:64位浮点数,M保存的时候可以把第一位的符号位省去,这样读取的时候可以把符号位加上去,这样就多了一位有效数字,64位的E就可以保存53位有效数字了
存的是小数点后面的数

对于E

E的值+中间值=存入内存中的值
32位浮点数的中间值为127
64位浮点数的中间值为1023
例如:2^5:的E为5,所以保存在内存中的值(float类型)为:5+127=132(10000100)

2.浮点数取的过程

从内存中取出来
浮点数的取可以分成三种情况:

1.E不全为0或E不全为1

E的值+中间值=存入内存中的值 M再加上首位(小数点前)的1

例如:

怎么存:0.5的表示为:(-1)^0 * 1.0*2^-1, S = 0,M = 1.0,E = -1,-1 + 127 = 126
0 01111110 00000000000000000000000

怎么取: 存入内存中的值 = 126,- 中间值 = - 127,= E的值 -1 (-1)^ 0 * 1.0 * 2 ^ -1

2.E全为0

0 00000000 0010000000000000000000
E:1-127=-126 有效数字M不再加上1,而是为:0.XXX
(-1)^0 * 1.0 * 2 ^ -129 这样就表示-+0,表示很小的数

3.E全为1

0 11111111 00100000000000000000000 (-1)^ 0 * 1.0 * 2 ^ 253
如果M全为0,表示很大的数:正负无穷 (S表示正负号)

三.浮点数的例题

9.0的二进制为:1001.0 (-1) ^ 0 * 1.001 * 2 ^ 3
S = 0
M = 1.001
E = 3
在内存中(二进制)为:
0 10000010 001000000000000000000000

0 00000000 00000000000000000001001
9.0 整型以浮点型打印:0.000000是输出的十进制
拿到是M的值,前面加上0
在这里插入图片描述

9.0浮点型以整型打印
0 10000010 01100000000000000000000
会打印出很大的数
这个二进制码的整数,原反补码都相同

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机常见的知识点(3)

计算机系统 系统的构成 一个完整的计算机系统是由硬件和软件组成 硬件是由运算器、控制器、存储器、输入设备、输出设备五部分组成 其中&#xff1a;中央处理器(简称CPU)运算器控制器 主机中央处理器主存储器 计算机软件包括计算机本身运行所需要的系统软件和用户完成任务…

jacoco使用示例与常用配置说明

基本概念 有时候&#xff0c;对于一些重要的项目或者重点类&#xff0c;我们希望重点测试&#xff0c;但是我们怎么评估测试质量呢&#xff1f; 这个时候&#xff0c;或许就需要jacoco了。 接下来&#xff0c;我们就来了解一下jacoco的基本概念与使用。 以及在某些条件不允…

Redis - list 列表

前言 列表类似于 Java 中的数组或者顺序表&#xff0c;在 Redis 中&#xff0c;可以对列表两端插⼊&#xff08;push&#xff09;和弹出&#xff08;pop&#xff09;&#xff0c;还可以获取指定范围的元素列表、 获取指定索引下标的元素等。列表是⼀种⽐较灵活的数据结构&#…

Loss-Attention

辅助信息 作者不开issue了&#xff0c;不建议复现

学习C++是否有必要学习Boost库?

C作为一门强大且灵活的编程语言&#xff0c;在软件开发领域有着广泛的应用。而在C的学习过程中&#xff0c;Boost库是一个经常被提及的重要资源。那么&#xff0c;对于C的学习者而言&#xff0c;是否有必要投入精力去学习Boost库呢&#xff1f;本文将就此问题展开详尽讨论。 一…

面试题:Java中的类加载器

1. 什么是类加载器&#xff0c;类加载器有哪些? 要想理解类加载器的话&#xff0c;务必要先清楚对于一个Java文件&#xff0c;它从编译到执行的整个过程。 类加载器&#xff1a;用于装载字节码文件(.class文件)运行时数据区&#xff1a;用于分配存储空间执行引擎&#xff1a;…

零代码编程:用kimichat批量重命名txt文本文件

一个文件夹中有很多个txt文本文件&#xff0c;需要全部进行重命名。 可以在kimichat中输入提示词&#xff1a; 你是一个Python编程专家&#xff0c;要完成一个关于批量重命名txt文本文件的Python脚本&#xff0c;下面是具体步骤&#xff1a; D:\Best Seller Books 这个文件夹…

chatGPT中文在线版本(亲测可用

ChatGPT是一个先进的自然语言处理模型&#xff0c;由OpenAI开发。它通过深度学习技术训练而成&#xff0c;可以进行对话、回答问题等多种自然语言处理任务。对于学生、开发者、研究人员和任何对人工智能感兴趣的人来说&#xff0c;这是一个非常有用的工具。 最近找到一个国内可…

【算法篇】逐步理解动态规划1(斐波那契数列模型)

目录 斐波那契数列模型 1. 第N个泰波那契数 2.使用最小花费爬楼梯 3.解码方法 学过算法的应该知道&#xff0c;动态规划一直都是一个非常难的模块&#xff0c;无论是状态转移方程的定义还是dp表的填表&#xff0c;都非常难找到思路。在这个算法的支线专题中我会结合很多力…

html网页制作-3D旋转卡片

网页制作-3D旋转卡片 两种旋转卡片的制作 旋转卡片&#xff08;1&#xff09; 代码 html代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-wid…

遍历目录下的某个文件并删除

目录 需求 编写过程 演示 需求 大家在学习时可能会有一个自己的小目录&#xff0c;里面放着各种奇葩代码&#xff0c;有天突然发现&#xff0c;没有空间了&#xff0c;这时候发现遗留了很多的可执行文件&#xff0c;大大的浪费了我们的空间&#xff0c;但是由于层数深&#…

汽车ABS的bangbang控制和模糊PID控制

1、内容简介 略 82-可以交流、咨询、答疑 2、内容说明 摘要&#xff1a;本文旨在设计一种利用模糊控制理论优化的pid控制器&#xff0c;控制abs系统&#xff0c;达到对滑移率最佳控制范围的要求 &#xff0c;所提出的方案采用级联控制架构&#xff1a;设计用于外环中的车轮打…