广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++浮点数类型详情
  • 541
分享到

C++浮点数类型详情

2024-04-02 19:04:59 541人浏览 泡泡鱼
摘要

目录1、浮点数2、关于m3、关于e4、浮点数的使用5、浮点数类型6、注意事项1、浮点数 浮点数是c++的第二组基本类型,它能够表示带小数部分的数字。不仅如此,浮点数的范围也比int更

1、浮点数

浮点数是c++的第二组基本类型,它能够表示带小数部分的数字。不仅如此,浮点数的范围也比int更大,可以表示更大范围的数字。

我们都知道在计算机当中,所有数据本质上都是转化成二进制存储的。整数很简单,存储的就是转化成二进制之后的01串,那么浮点数又是如何存储的呢?

很容易猜到的是浮点数存储的结果也是二进制,但相比于整型直接转化成二进制要复杂一些。

它需要先表示成下面这行式子:

这里的n即我们要存储的浮点数,s表示符号位,m是尾数,而e则是阶数。

符号位很好理解,它和整型当中的符号位一样,0表示正数,1表示负数。m表示尾数,。我们这么看很抽象,来看一个例子,比如3.0,转化成二进制是,相当于。那么,。

我们了解了浮点数的表示方式,那么它又是如何存储在计算机当中的呢?这需要我们进一步地剖析其中的细节。

2、关于m

首先是mm被定义成一个大于等于1,小于2的小数。我们可以简单写成1.xx,其中xx表示的就是小数的部分。

既然它总是大于等于1,小于2的,那么它的个位一定是1,我们就可以将它省略,仅仅看之后小数的部分。小数的部分,我们同样使用二进制来逼近。比如0.625,可以表示成0.5 + 0.125,即,表示成二进制就是,只不过这里它的最高位是从-1开始的。

以32位的浮点数为例,除去1位表示符号,8位表示阶数之后,还有23位留给m。由于我们舍掉了小数点之前的1,所以我们的阶数是从-1开始的,理论上等价于24个二进制位。

3、关于e

在浮点数存储当中,e是一个无符号整数。以32位浮点数为例,e一共有8位,可以表示0-255。

但e是可以为负数的,根据IEEE 754的规定,e的真实值必须再减去一个中间数。对于8位的e,它的中间数是127。比如e的实际值是10,但是存储的时候需要存储成127+10=137

除此之外,e还有另外三种情况:

  • e不全为0,或全为1时,采用上述的规则表示
  • e全为0时,e等于1-127,有效数字m不再默认加上1,这样是为了还原0.xxx的小数,以及接近于0的数
  • e全为1时,如果有效数字m全为0,表示无穷大,如果m不全为0,表示nan(not a number)

关于e的规则看起来有些复杂,初看觉得有些难以理解,为什么要用减去中间值的设计,而不用符号位?后来仔细思考了一下才发现,如果引入符号位很难区分0.xxx以及e就是等于0的情况,虽然也可以特判处理,但就没有现在这样优雅了。

觉得上文看不懂的小伙伴可以直接略过这段,毕竟这个是浮点数的实现原理,算是很底层的内容了,C++ primer上对于这部分也没有过多阐述。

4、浮点数的使用

C++当中有两种浮点数的书写方式,第一种是使用常规的小数点表示法:


double a = 1.23;
float b = 3.43;


另外一种写法是科学记数法,写成:


double a = 2.45e8;
double b = 1e-7;


2.45e8表示,e之后可以跟正数也可以跟负数,但数字当中不能有空格。

5、浮点数类型

C语言一样,C++也有三种浮点数类型:float,doublelong double。和整型一样,这三种类型都是浮点数,只不过表示的范围不同。

浮点数的范围有两个部分综合决定,一个部分是有效数字。比如14179是5位有效数字,而14000只有两位,因为后面三个0都是填充位,有效数字的位数不依赖小数点的位置。C++当中要求,float通常表示7位有效数字,double通常16位位,而long double至少和double一样。

另外,它们能够表达的指数范围至少是-37到37。一般来说,float一共是4个字节32位,而double是8个字节64位,当然这也取决于具体的运行环境。

6、注意事项

关于浮点数的使用有几点注意事项,千万要注意。

  • cout输出浮点数会删除结尾的0
  • 书写浮点数常量时默认为double类型,如果需要强制表示为float类型,请在结尾加上后缀f或者F,如:2.34f
  • 由于浮点数有精度,不能直接判断两个浮点数是否相等,很有可能得不到预期结果,正确的做法是判断精度范围,

如:


double epsilon = 1e-8;
// 判断a是否和b相等
if (abs(a - b) < epsilon) {
    // todo
}

判断两个浮点数a和b是否相等,等价于两者的差的绝对值小于某一个精度。

范围问题,如运行下列代码将得到错误的结果:


float a = 2.3e22f;
float b = a + 1.0f;

cout << b - a << endl;

输出的结果将是0,因为2.3e22是一个小数点左边有23位的数字,加上1之后,就是在第23位加上1。但是float类型只能表示数字中的前6位或者前7位,表示不了这么高的精度,因此这个+1的操作完全没有生效。

这个问题是一个大坑,一不小心就会中招,千万要小心。

到此这篇关于C++浮点数类型详情的文章就介绍到这了,更多相关C++浮点数类型内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

注:文章转自微信公众号:Coder梁(ID:Coder_LT)

--结束END--

本文标题: C++浮点数类型详情

本文链接: https://www.lsjlt.com/news/156247.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++浮点数类型详情
    目录1、浮点数2、关于m3、关于e4、浮点数的使用5、浮点数类型6、注意事项1、浮点数 浮点数是C++的第二组基本类型,它能够表示带小数部分的数字。不仅如此,浮点数的范围也比int更...
    99+
    2022-11-12
  • C语言中的浮点数据类型
    目录1. 处理带小数的数值2. 浮点类型 3. 浮点类型的sizeof1. 处理带小数的数值 我们来讨论一下类似于1.234567,0.00001,这类非整数的数据。我们先试试看,i...
    99+
    2022-11-12
  • C# 变量,常量数据类型详情
    目录1、变量操作1.1 变量声明、赋值1.2 赋值运算符和赋值表达式1.4变量命名规则2 常量2.1 变量常量作用域2.2 @作用3 数据类型之值类型3.1数据类型3.2 理解内存原...
    99+
    2022-11-13
  • pytorch和numpy默认浮点类型位数详解
    目录pytorch和numpy默认浮点类型位数测试代码如下pytorch和numpy的默认类型与转换问题总结pytorch和numpy默认浮点类型位数 numpy中默认浮点类型为64...
    99+
    2023-02-02
    pytorch numpy numpy默认浮点类型位数 pytorch默认浮点类型
  • 【⑬MySQL | 数据类型(一)】简介 | 整数 | 浮点 | 定点类型
    前言 ✨欢迎来到小K的MySQL专栏,本节将为大家带来MySQL数据类型简介 | 整数 | 浮点 | 定点类型的分享✨ 目录 前言0.数据类型简介1 整数类型2 浮点类型3 定点类型4 日期/时间类型总结 0...
    99+
    2023-08-24
    mysql android 数据库
  • C++类型兼容规则详情
    在类的继承过程中,子类继承了父类除去构造函数和析构函数外的所有成员,那么父类的功能子类是不是都有呢? 实际上,子类是否含有父类的全部功能,取决于“继承方式”。...
    99+
    2022-11-13
  • C++浮点型的存储方式详解
    目录浮点型及其存储方式一、IEEE浮点标准二、存储方式IEEE 754对有效数字M和指数E的规定。重点:根据指数域不同取值分为一下三种情况: 总结浮点型及其存储方式 有些时...
    99+
    2022-11-12
  • C++自定义数据类型方法详情
    目录1、typedef声明2、枚举类型enum1、typedef声明 typedef用于给已有的类型一个新的名字,这个新的名字可以是自己定义的, 其语法为: typedef 现有类型...
    99+
    2022-11-13
  • MySQL 数据类型详情
    目录1、数值类型1.1、数值类型分类1.1.1、浮点数1.1.2、位类型1.1.3、时间日期类型1.1.4、字符串类型1.1.5、ENUM 类型1.1.6、SET类型1、数值类型 1...
    99+
    2022-11-12
  • 【⑬MySQL | 数据类型(一)】简介 | 整数 | 浮点 | 定点 | 时间/日期类型
    前言 ✨欢迎来到小K的MySQL专栏,本节将为大家带来MySQL数据类型简介 | 整数 | 浮点 | 定点 | 时间/日期类型的分享✨ 目录 前言0.数据类型简介1 整数类型2 浮点类型3 定点类型4 日期/时间类型总结 ...
    99+
    2023-08-30
    mysql android 数据库
  • C语言详细图解浮点型数据的存储实现
    目录在引入知识之前,先来看一个案例,就知道了解浮点型数据存储的重要性与必要性。 举个例子: #define _CRT_SECURE_NO_WARNINGS 1 #include<...
    99+
    2022-11-13
  • php如何将整数转为浮点数类型
    这篇文章主要为大家展示了“php如何将整数转为浮点数类型”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“php如何将整数转为浮点数类型”这篇文章吧。php将整数转为浮点数类型的方法:1、在要转换的...
    99+
    2023-06-20
  • python如何转为浮点类型
    小编给大家分享一下python如何转为浮点类型,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!转为浮...
    99+
    2022-10-19
  • java浮点类型案例介绍
      java浮点类型介绍在学习java开发中,那么java浮点类型是我们必不可少学习的知识点,下面介绍一下java浮点类型。1. float型常量:453.5439f,21379.987F,231.0f(小数表示法),2...
    99+
    2023-06-03
  • mysql中什么是浮点类型
    这篇文章主要讲解了“mysql中什么是浮点类型”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql中什么是浮点类型”吧!说明MySQL对小数的表示分为浮点数和定点数两种。浮点数包括flo...
    99+
    2023-06-20
  • 重学c/c++之数据存储详解(整数、浮点数)
    目录一:整形正常情况下特殊情况下有符号数据溢出()补充二:浮点型总结一:整形 正常情况下 正数在内存中的存储为补码。 char a=30; 00011110(计算机中的存储) 负数在...
    99+
    2022-11-13
    c++ 数据存储 c语言存储数据 c++存储数据的方式
  • 分享C++三种类型new类型的运算符使用详情
    目录1.new操作符2.::operator new2.1原始调用2.2重载12.3重载23.place new1.new操作符 new operator,平时用的最多的new操作符...
    99+
    2022-11-13
  • C语言中字符型数据和浮点型数据介绍
    目录字符型1.来练练,输出一个字符A2.将小写字母转为大写字母浮点型先来看看float代码以下是双精度的浮点型double练习题新的一天又开始了哈,又是好好学习的一天啦。话不多说,直...
    99+
    2022-11-12
  • Golang通脉之数据类型详情
    目录1、标识符与关键字1.1 标识符1.2 关键字2、变量2.1 什么是变量2.2 变量类型2.3 变量声明3、常量3.1 iota4、基本数据类型4.1 整型4.2 浮点型4.3 ...
    99+
    2022-11-12
  • python_tkinter事件类型详情
    目录1.事件绑定函数2.事件类型3.事件对象1.事件绑定函数 事件绑定函数有三个如下:        组件.bind('事件类型...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作