C#的数据类型总结:decimal ,double,float的区别

embedded/2024/11/25 8:03:00/

在 C# 中,decimaldoublefloat 都是用于表示数值类型的关键字,但它们在精度、范围和用途上有所不同。以下是它们的主要区别和适用场景的总结。

目录

1. decimal

2. double

3. float

主要比较

适用场景总结

注意点


1. decimal

  • 类型大小: 16 字节 (128 位)

  • 有效位数: 28-29 位十进制数字

  • 用途: 精确的十进制数值运算,如货币计算、金融计算等。

  • 特点:

    • 精度较高,特别适合需要精确表示的十进制数值。
    • 它的精度主要针对小数部分,避免了二进制浮点数在十进制运算时可能出现的舍入误差。
    • 计算速度相对较慢,因为它是针对高精度场景优化的。
  • 代码示例:

    decimal price = 19.99m; // 必须使用后缀 'm' 表示 decimal 类型
    decimal total = price * 3; // 精确的十进制运算
    Console.WriteLine(total); // 输出: 59.97
    

2. double

  • 类型大小: 8 字节 (64 位)

  • 有效位数: 15-16 位十进制数字

  • 用途: 科学计算、大范围数值运算,尤其适合需要处理非常大的或非常小的数值。

  • 特点:

    • 使用 IEEE 754 标准的双精度浮点数。
    • 范围很大,适合处理需要高动态范围的数值,但精度不足以处理非常精确的小数运算。
    • 二进制表示法可能导致十进制小数转换时的舍入误差。
  • 代码示例:

    double pi = 3.141592653589793;
    double area = pi * 100000 * 100000;
    Console.WriteLine(area); // 输出: 3.141592653589793E+10
    


3. float

  • 类型大小: 4 字节 (32 位)

  • 有效位数: 6-7 位十进制数字

  • 用途: 需要节省内存并对精度要求较低的场景,如游戏编程、图形处理等。

  • 特点:

    • 使用 IEEE 754 标准的单精度浮点数。
    • 占用内存较小,但精度较低,容易出现舍入误差。
    • 适合处理范围不大且对性能要求较高的数值。
  • 代码示例:

    float value = 1.2345678f; // 必须使用后缀 'f' 表示 float 类型
    Console.WriteLine(value); // 输出: 1.234568 (精度不足以保留全部小数)
    


主要比较

特性decimaldoublefloat
字节大小16 字节 (128 位)8 字节 (64 位)4 字节 (32 位)
有效位数28-29 位十进制数字15-16 位十进制数字6-7 位十进制数字
范围较小 (±1.0 × 10^-28 到 ±7.9 × 10^28)非常大 (±5.0 × 10^-324 到 ±1.7 × 10^308)大 (±1.5 × 10^-45 到 ±3.4 × 10^38)
精度高 (适合精确运算)中 (科学计算)低 (内存和性能优化)
速度较慢较快最快
用途财务、货币计算科学计算、工程计算内存受限的场景,如图形编程

适用场景总结

  1. 使用 decimal:

    • 当需要高精度计算且主要处理十进制数时,例如货币、财务报表、税务计算。
  2. 使用 double:

    • 当需要大范围和高动态范围的数值运算时,例如科学计算、复杂物理模拟。
  3. 使用 float:

    • 当内存和性能优先且对精度要求较低时,例如游戏开发、实时渲染、图形处理。

注意点

  • 默认小数值为 double,因此需要用后缀 m 表示 decimal,用后缀 f 表示 float
  • 对于需要极高精度的场景,推荐使用 decimal
  • floatdouble 不适合用于货币计算,可能引入舍入误差。

http://www.ppmy.cn/embedded/140330.html

相关文章

解释 Python 中的可变与不可变数据类型?

在 Python 中,数据类型分为可变(mutable)和不可变(immutable)两种。 理解这两种类型的区别对于编写高效、可靠的代码至关重要。 作为面试官,我会详细解释这两者的区别,并提供一些实际开发中的…

一文读懂 ESLint配置

你好,我是Qiuner. 为帮助别人少走弯路和记录自己编程学习过程而写博客 这是我的 github https://github.com/Qiuner ⭐️ ​ gitee https://gitee.com/Qiuner 🌹 如果本篇文章帮到了你 不妨点个赞吧~ 我会很高兴的 😄 (^ ~ ^) 想看更多 那就点个关注吧 我…

正则表达式灾难:重新认识“KISS原则”的意义

大家好,这里是hikktn! 最近,我在重读经典名著《The Art of Unix Programming》,又一次被那句广为人知的“KISS”原则(Keep It Simple, Stupid)吸引。这句计算机领域的金科玉律,很多人只停留在字…

AwsCredentialsProvider认证接口

一、介绍 1、简介 AwsCredentialsProvider 是 AWS SDK 中用于提供 AWS 身份验证凭证的一个接口。AWS SDK 中涉及身份验证和授权的操作都需要用到凭证,而 AwsCredentialsProvider 作为一种抽象,负责提供这些凭证。AwsCredentialsProvider 在 Java SDK 中尤为重要,它可以用于…

【网络安全设备系列】3、IPS(入侵防御系统)

0x00 定义: 入侵防御系统是一部能够监视网络或网络设备的网络资料传输行为的计算机网络安全设备,能够即时的中断、调整或隔离一些不正常或是具有伤害性的网络资料传输行为。 0x01 产生背景 : 1、串行部署的防火墙可以拦截低层攻击行为&a…

C 语言复习总结记录二

C 语言复习总结记录二 一 控制语句 1、语句的分类 表达式语句函数调用语句复合语句控制语句空语句 控制语句 控制程序的执行流程,实现程序的各种结构方式 C 语言支持三种结构 :顺序结构、选择结构、循环结构,由特定的语句定义符组成C语言…

Qt关于窗口一直调用paintEvent的踩坑实录

首先看以下代码&#xff1a; void ItemBlockWidget::paintEvent(QPaintEvent *ev) {// 先调用父类的 paintEvent 以执行默认绘制行为QWidget::paintEvent(ev);qDebug()<<"ItemBlockWidget重绘";QStyleOption opt;opt.initFrom(this);QPainter p(this);style()…

windows11下git与 openssl要注意的问题

看了一下自己贴文的历史&#xff0c;有一条重要的忘了写了。 当时帮有位同事配置gitlab&#xff0c;众说周知gitlab是不太好操作。 但我还是自认自己git还是相当熟的。 解决了一系列问题&#xff0c;如配置代理&#xff0c;sshkey&#xff0c;私有库&#xff0c;等等&#xff0…