首页 > 其他分享 >math 库中常用的数学运算和常量【GO 基础】

math 库中常用的数学运算和常量【GO 基础】

时间:2023-09-22 18:33:35浏览次数:51  
标签:func float64 fmt Println 库中 GO main math

〇、关于 math

GO 语言的 math 库是一个内置的标准库,其中包含了许多数学函数和常量,用于计算各种数学运算和统计学计算。

日常开发中,计算当然是少不了的,那么今天来梳理下备查。

一、测试示例

1.1 小数位的:Round-四舍五入、RoundToEven-四舍/五至偶数

func Round(x float64 ) float64func 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  // 默认为六位小数
}

1.2 小数位的:ceil-进一法、Floor-去尾法、Trunc-取整数部分

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))
}

1.3 Mod-取余、取整、Remainder-距离整除差值、Modf-分别取整数和小数部分

先看下除法运算,结果的值的精度依赖于被除数。当被除数为整数,则结果自动取整;当被除数为 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)
}

1.4 Max-最大值、Min-最小值

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))
}

1.5 Dim-差的绝对值(标准差)

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))
}

1.6 Abs-绝对值、Sqrt-平方根、Cbrt-立方根、Pow-数值的 n 次方、Pow10-10 的 n 次方

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
}

1.7 NaN-取一个非数字的值、IsNaN-判断值是否为非数字

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))
}

 

1.8 Signbit-判断值是负数,0 或正数返回 false

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))
}

二、math 中的数学常量

如下常用的数学常量示例:

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())
}

其他常用数学常量还有:

  • MaxInt8、MaxInt16、MaxInt32、MaxInt64:表示各种整数类型的最大值。
  • MinInt8、MinInt16、MinInt32、MinInt64:表示各种整数类型的最小值。
  • MaxFloat32、MaxFloat64:表示各种浮点数类型的最大值。
  • MinFloat32、MinFloat64:表示各种浮点数类型的最小值。

参考:https://golang.google.cn/pkg/math/

标签:func,float64,fmt,Println,库中,GO,main,math
From: https://www.cnblogs.com/hnzhengfy/p/GO_math.html

相关文章

  • 通过 BigQuery 中的 11 个新链增强 Google Cloud 的区块链数据服务
    【CloudAce 是GoogleCloud全球战略合作伙伴,在亚太地区、欧洲、南北美洲和非洲拥有二十多个办公室。CloudAce在谷歌专业领域认证及专业知识目前排名全球第一位,并连续多次获得GoogleCloud各类奖项。作为谷歌云托管服务商,我们提供谷歌云、谷歌地图、谷歌办公套件、谷歌云认......
  • RunnerGo使用流程
    性能测试—计划管理新建计划:在左侧导航栏中,选择“性能测试”,点击“计划管理”进入计划管理界面,点击右上角新建计划来新建测试计划。任务类型选择后不可再更改。定时模式下,该计划内最多只能创建一个场景。普通任务:支持当即执行计划;定时任务:可预设计划开始运行的时间和频次,频......
  • [SpringSecurity5.6.2源码分析十三]:LogoutFilter
    前言• SpringSecurity默认提供了登录的页面以及登录的接口,与之对应的也提供了登出页和登出请求• 登出请求对应的过滤器是LogoutFilter• 登出页对应的是DefaultLogoutPageGeneratingFilter、1.LogoutConfigurer• LogoutConfigurer是LogoutFilter对应的配置类,先看其主要方法......
  • 使用JDBC插入数据时,数据库中文显示为?的解决方法
    问题描述:使用JDBC进行添加数据的操作,设置的参数为中文,运行成功后数据库显示插入的数据为??解决方法:配置url时加上?useUnicode=true&characterEncoding=UTF-8重新进行插入:结果显示正确。......
  • JS实现电子签名,并且将带logo和时间水印的电子签名保存到本地
    页面效果如下 本地保存的电子签名图片如下 具体实现代码如下<!DOCTYPEhtml><html><head><metacharset="utf-8"><title>电子签名</title><style>#canvas{border:1pxsolid#000;margin-bo......
  • go基础学习
    坏境安装SDK下载地址windows安装可以直接下载安装msi不需要配置坏境变量默认配置好了zip里面包含源码,但是需要配置坏境变量liunx安装SDKwgethttps://dl.google.com/go/go1.20.2.linux-amd64.tar.gztar-C/usr/local-xzfgo1.20.2.linux-amd64.tar.gzcd......
  • 将hive数据库中的数据导入到mysql数据库中时需要注意到的问题
    在hive中使用jdbc将hive与mysql连接起来时一定要注意到每个数据库不同的字段个数,在打算直接复制时,不能只是修改表的名称和字段名称,还要记得修改几个?那里,个数要与字段名称保持一致!!!不然就会报错(比如我);......
  • (MongoDB)windows 下使用 MongoDB
    1.安装MongoDBServer 访问 https://www.mongodb.com/try/download/community,找到“MongoDBCommunityServerDownload”并下载  2.安装MongoDB  安装MongoDBServer,并安装随带的MongoDBCompass 安装完成后,MongoDBServer将即时启动(需要重启), 查看......
  • 已解决ValueError: Expected 2D array, got 1D array instead
    已解决ValueError:Expected2Darray,got1Darrayinstead文章目录报错问题解决方法声明报错问题之前在工作中遇到过这个坑,记录一下问题以及解决方法,不一定针对所有情况都能用,但是可以供大家参考。问题描述如下:ValueError:Expected2Darray,got1DarrayinsteadReshapey......
  • Django 聚合查询中 加减操作
    查询订单的定金+支付金额-支付金额错误写法Order.objects.aggregate(sum=Sum(F('final_amt')+F('deposit_amt')-F('refund_amt'))))正确的信息Order.objects.aggregate(sum=Sum(('final_amt')+Sum('......