Go语言浮点数完全手册 float32和float64一文掌握!

简介: Go语言浮点数完全手册 float32和float64一文掌握!

浮点数是一种可以表示小数的数字类型。在 Go 语言中,提供了两种浮点数类型:float32 和 float64。理解浮点数的表示范围和精度非常重要,这关系到我们选择合适的浮点类型。

本文将详细介绍 Go 语言中浮点数类型的表示范围、精度选择、初始化和使用等内容。

1

 

一、浮点数类型

Go 语言提供了两种浮点数类型:

  1. float32:32 位浮点数
  2. float64:64 位浮点数(默认的浮点数类型)

float32 占 4 个字节,float64 占 8 个字节。

2

 

二、float32 和 float64 的区别

float32 和 float64 的区别主要在于表示的最大范围以及精度不同:

  1. float32 表示范围约为 3.4e38,精度可达 7 位有效数字;
  2. float64 表示范围约为 1.8e308,精度可达 15 位有效数字。

在大多数情况下我们应该使用 float64,因为它的精度更高。只有在需要节省内存空间的时候才使用 float32。

3

 

三、浮点数的机理

Go 语言的浮点数采用了 IEEE 754 标准的浮点数编码。该编码使用 1 个符号位、几个阶码位和尾数位来表示浮点数:

  • 符号位表示正负;
  • 阶码表示指数;
  • 尾数表示有效数字。

举个例子:

5.12 = 1.101 * 2^(2)
  • 1.101 就是尾数部分,也叫小数部分;
  • 2 就是阶码,表示 2 个指数;
  • 1 是符号位,正数为 0,负数为 1。

这样就能表示很大范围的浮点数了。

4

 

四、浮点数的范围

我们来看下 float32 和 float64 表示的最大最小范围:

  • float32:大约 ±3.4e38
  • float64:大约 ±1.8e308

再具体一点,float64 的范围是:

最大值:1.7976931348623157e+308

最小值:2.2250738585072014e-308

需要注意的是,超出该范围的浮点数会变成无穷大或无穷小。

5

 

五、浮点数的精度

float32 的精度为 7 位有效数字,float64 的精度为 15 位有效数字。

举个例子:

var a float32 = 1.123456789
var b float64 = 1.123456789
fmt.Println(a) // 1.1234568
fmt.Println(b) // 1.123456789

可以看到 float64 能保留更多的精度。

6

 

六、浮点数的初始化

初始化浮点数可以通过 float32()和 float64()函数来显式指定类型:

var a float32 = float32(3.14)
var b float64 = float64(3.141592653)

不指定时,默认声明 float64 类型:

var c = 3.14 // float64类型

7

 

七、示例代码

下面我们看一个浮点数运算的简单示例:

package main
import "fmt"
func main() {
  var price float64 = 89.12
  var discount float64 = 0.5
  var result float64 
  result = price * discount
  fmt.Println("支付金额:",result) 
}

输出结果:

支付金额: 44.56

通过这个例子可以看出 Go 语言可以很方便地进行浮点数的运算。

8

 

总结

Go 语言作为一门高性能编程语言,提供了可选择的 float32 和 float64 两种浮点数类型。我们应该根据实际的精度需求选择合适的浮点类型,一般默认使用 float64 就可以满足大多数需求了。掌握了浮点数的表示特点后,我们可以更好地运用浮点数进行各种运算。


目录
相关文章
|
5天前
|
JSON 测试技术 Go
零值在go语言和初始化数据
【7月更文挑战第10天】本文介绍在Go语言中如何初始化数据,未初始化的变量会有对应的零值:bool为`false`,int为`0`,byte和string为空,pointer、function、interface及channel为`nil`,slice和map也为`nil`。。本文档作为指南,帮助理解Go的数据结构和正确使用它们。
53 22
零值在go语言和初始化数据
|
5天前
|
JSON Java Go
Go 语言性能优化技巧
在Go语言中优化性能涉及数字字符串转换(如用`strconv.Itoa()`代替`fmt.Sprintf()`)、避免不必要的字符串到字节切片转换、预分配切片容量、使用`strings.Builder`拼接、有效利用并发(`goroutine`和`sync.WaitGroup`)、减少内存分配、对象重用(`sync.Pool`)、无锁编程、I/O缓冲、正则预编译和选择高效的序列化方法。这些策略能显著提升代码执行效率和系统资源利用率。
42 13
|
1天前
|
Cloud Native Java Go
为什么要学习Go语言?
GO logo的核心理念,即简单胜于复杂。使用现代斜体无衬线字体与三条简单的运动线相结合,形成一个类似于快速运动的两个轮子的标记,传达速度和效率。字母的圆形暗示了GO地鼠的眼睛,创造了一个熟悉的形状,让标记和吉祥物很好地搭配在一起。
12 4
|
5天前
|
设计模式 Go
Go语言设计模式:使用Option模式简化类的初始化
在Go语言中,面对构造函数参数过多导致的复杂性问题,可以采用Option模式。Option模式通过函数选项提供灵活的配置,增强了构造函数的可读性和可扩展性。以`Foo`为例,通过定义如`WithName`、`WithAge`、`WithDB`等设置器函数,调用者可以选择性地传递所需参数,避免了记忆参数顺序和类型。这种模式提升了代码的维护性和灵活性,特别是在处理多配置场景时。
41 8
|
5天前
|
存储 Go
go语言中fmt格式化包和内置函数汇总
【7月更文挑战第10天】本文介绍fmt包和`Errorf`用于创建格式化的错误消息。`fmt`包还涉及一些接口,如`Formatter`、`GoStringer`、`ScanState`、`Scanner`和`Stringer`,支持自定义格式化和输入/输出处理。
17 1
|
5天前
|
Go
go语言中格式化输出的占位符
【7月更文挑战第10天】`fmt` 包在 Go 语言中用于格式化输出,包括不同类型的占位符:%v(默认格式)、%+v(带字段名的结构体)、%#v(Go语法表示)、%T(类型表示)、%%(百分号)。布尔值用%t,整数有%b、%c、%d、%o、%q、%x、%X和%U。浮点数和复数用%b、%e、%E、%f、%g、%G。字符串和字节切片用%s、%q、%x、%X。指针用%p。占位符可配合+、-、#、空格和0进行调整。宽度和精度控制输出格式,例如 %.4g 控制小数精度。Go 没有 `%u`,但无符号整数默认打印为正数。运算符包括逻辑、比较、加减、乘除、移位、按位和按位异或等。
17 1
|
7天前
|
存储 Go 索引
在go语言中自定义泛型的变长参数
【7月更文挑战第8天】在Go语言中,由于官方1.18以前的版本不支持泛型,可以通过空接口和反射模拟泛型。泛型适用于通用数据结构和函数,虽牺牲了一些性能,但提高了代码复用和类型安全性。
42 1
|
3天前
|
安全 Go
Go语言map并发安全,互斥锁和读写锁谁更优?
Go并发编程中,`sync.Mutex`提供独占访问,适合读写操作均衡或写操作频繁的场景;`sync.RWMutex`允许多个读取者并行,适用于读多写少的情况。明智选择锁可提升程序性能和稳定性。示例展示了如何在操作map时使用这两种锁。
6 0
|
3天前
|
安全 Go 开发者
Go语言map并发安全使用的正确姿势
在Go并发编程中,由于普通map不是线程安全的,多goroutine访问可能导致数据竞态。为保证安全,可使用`sync.Mutex`封装map或使用从Go 1.9开始提供的`sync.Map`。前者通过加锁手动同步,后者内置并发控制,适用于多goroutine共享。选择哪种取决于具体场景和性能需求。
6 0
|
3天前
|
存储 安全 Java
Go语言中的map为什么默认不是并发安全的?
Go语言的map默认不保证并发安全,以优化性能和简洁性。官方建议在需要时使用`sync.Mutex`保证安全。从Go 1.6起,并发读写map会导致程序崩溃,鼓励开发者显式处理并发问题。这样做的哲学是让代码更清晰,并避免不必要的性能开销。
4 0