GO 语言的 math 库是一个内置的标准库,其中包含了许多数学函数和常量,用于计算各种数学运算和统计学计算。
日常开发中,计算当然是少不了的,那么今天来梳理下备查。
func Round(x float64 ) float64
、func RoundToEven(x float64 ) float64
如下测试代码和结果:
package main
import (
"fmt"
"math"
)
func main() {
fmt.Printf("math.Round(3.4):%v\n", math.Round(3.4))
fmt.Printf("math.Round(3.5):%v\n", math.Round(3.5))
fmt.Printf("math.Round(3.6):%v\n", math.Round(3.6))
// fmt.Printf("math.RoundToEven(3.5): %f\n", math.RoundToEven(3.4))
// fmt.Printf("math.RoundToEven(4.5): %f\n", math.RoundToEven(4.4))
fmt.Printf("math.RoundToEven(3.5): %f\n", math.RoundToEven(3.5))
fmt.Printf("math.RoundToEven(4.5): %f\n", math.RoundToEven(4.5))
// %f 输出精度格式:%总位数.小数位数f // 默认为六位小数
}
func Ceil(x float64 ) float64
func Floor(x float64 ) float64
func Trunc(x float64 ) float64
package main
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Ceil(1.4))
fmt.Println(math.Ceil(1.8))
fmt.Println(math.Floor(1.4))
fmt.Println(math.Floor(1.8))
fmt.Println(math.Trunc(1.4))
fmt.Println(math.Trunc(1.8))
}
先看下除法运算,结果的值的精度依赖于被除数。当被除数为整数,则结果自动取整;当被除数为 float32,结果默认为带七位小数的浮点数;若为 float64 则结果保留16 位小数。如下示例:
package main
import (
"fmt"
)
func main() {
result_int := 8 / 3
result_float := float32(8) / 3
fmt.Printf("int : %v\n", result_int)
fmt.Printf("float: %v\n", result_float)
float_a := 7.7 // 默认为:float64
float_b := 3.3
fmt.Println("a/b-32 :", float32(float_a)/float32(float_b)) // float32 默认保留 7 位
fmt.Println("a/b-64 :", float_a/float_b) // float64 默认保留 16 位
num2 := fmt.Sprintf("%.5f", float_a/float_b) // 手动指定保留 5 位
fmt.Println("指定保留5位小数:", num2)
}
取整和取余
package main
import (
"fmt"
)
func main() {
// 取整
result_int := 8 / 3
fmt.Printf("%v\n", result_int) // 输出:2
// 取余
int_a := 7
int_b := 4
fmt.Println(int_a % int_b) // 输出:3 // 百分号 % 用来取余数,只能用于整数之间
}
采用func Mod(x, y float64 ) float64
取余:
package main
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Mod(7, 4))
fmt.Println(math.Mod(7.2, 4))
fmt.Println(math.Mod(7, 4.1))
fmt.Println(math.Mod(7.2, 4.1))
}
通过func Remainder(x, y float64) float64
计算整除剩余值:
package main
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Remainder(7, 4))
fmt.Println(math.Remainder(7.2, 4))
fmt.Println(math.Remainder(7, 4.1))
fmt.Println(math.Remainder(7.2, 4.1))
}
通过func Modf(f float64) (int float64, frac float64)
取整数和小数部分:
package main
import (
"fmt"
"math"
)
func main() {
intv, frac := math.Modf(3.14)
fmt.Println(intv)
fmt.Printf("%f", frac)
}
func Max(x, y float64 ) float64
func Min(x, y float64 ) float64
package main
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Max(1.5, 4.5))
fmt.Println(math.Max(-1.5, -4.5))
fmt.Println(math.Min(1.5, 4.5))
fmt.Println(math.Min(-1.5, -4.5))
}
func Dim(x, y float64 ) float64
package main
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Dim(-1.4, -4))
fmt.Println(math.Dim(-0.4, -40))
}
func Abs(x float64 ) float64
func Sqrt(x float64) float64
func Cbrt(x float64) float64
func Pow(x, y float64 ) float64
func Pow10(n int) float64
package main
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Abs(-1.4))
fmt.Println(math.Sqrt(9))
fmt.Println(math.Cbrt(8))
fmt.Println(math.Pow(2, 2))
fmt.Println(math.Pow(2, 3))
fmt.Println(math.Pow10(2)) // 输出:100
}
func NaN() float64
func IsNaN(f float64) (is bool)
package main
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.IsNaN(-1.4))
nan := math.NaN()
fmt.Println(math.IsNaN(nan))
}
func Signbit(x float64) bool
package main
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Signbit(-1))
fmt.Println(math.Signbit(0))
fmt.Println(math.Signbit(1))
}
如下常用的数学常量示例:
package main
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Pi)
fmt.Println(math.E)
fmt.Println(math.Inf(-1))
fmt.Println(math.Inf(0))
fmt.Println(math.NaN())
}
其他常用数学常量还有: