一文带你了解Go语言标准库math和rand的常用函数
作者:陈明勇 发布时间:2024-02-22 07:24:24
math 标准库
math
标准库提供了一些 常量如 int64
类型的最大值、float64
类型的最大值等,和常用的数学计算函数。
常用函数
函数 | 说明 |
---|---|
Abs(x float64) float64 | 传入 x 参数,返回 x 的绝对值 |
Max(x, y float64) float64 | 传入 x、y 参数,返回 x 与 y 中的最大值 |
Min(x, y float64) float64 | 传入 x、y 参数,返回 x 和 y 中的最小值 |
Ceil(x float64) float64 | 传入 x 参数,返回一个大于等于 x 的最小整数值,也就是向上取整 |
Ceil(x float64) float64 | 传入 x 参数,返回一个小于等于 x 的最小整数值,也就是向下取整 |
Trunc(x float64) float64 | 传入 x 参数,返回浮点数 x 的整数部分,使用 Floor 函数也能实现 |
Dim(x, y float64) float64 | 传入 x、y 参数,返回 x-y 与 0 中最大的值 |
Mod(x, y float64) float64 | 对 x / y 进行取余运算 x % y |
Pow(x, y float64) float64 | 计算 x 的 y 次幂 |
Sqrt(x float64) float64 | 对 x 开平方 |
Cbrt(x float64) float64 | 对 x 开立方 |
Modf(f float64) (int float64, frac float64) | 分别取出 f 的整数部分和小数部分 |
如果想了解更多函数介绍和使用,可以到 pkg.go.dev/math 进行查看。
Abs 函数
Abs(x float64) float64
:返回 x
的绝对值。 示例:
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Abs(-3.14)) // 3.14
}
Max 函数
Max(x, y float64) float64
:返回 x
与 y
中的最大值。 示例:
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Max(1.5, 2.5)) // 2.5
}
Min 函数
Min(x, y float64) float64
:返回 x
和 y
中的最小值。 示例:
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Min(1.5, 2.5)) // 1.5
}
Ceil
Ceil(x float64) float64
:返回一个大于等于 x
的最小整数值,也就是向上取整。 示例:
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Ceil(1.4)) // 2
fmt.Println(math.Ceil(2)) // 2
}
Floor 函数
Ceil(x float64) float64
:返回一个小于等于 x
的最小整数值,也就是向下取整。 示例:
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Floor(1.4)) // 1
fmt.Println(math.Floor(1)) // 1
}
Trunc 函数
Trunc(x float64) float64
:返回浮点数 x
的整数部分,使用 Floor
函数也能实现。 示例:
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Trunc(1.4)) // 1
}
Dim 函数
Dim(x, y float64) float64
:返回 x-y
与 0
中最大的值。 示例:
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Dim(2.0, 1.0)) // 1
fmt.Println(math.Dim(1.0, 2.0)) // 0
}
Mod 函数
Mod(x, y float64) float64
:对 x / y
进行取余运算 x % y
。 示例:
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Mod(5.0, 3.0)) // 3
fmt.Println(math.Mod(3.0, 3.0)) // 0
}
Pow 函数
Pow(x, y float64) float64
:计算 x
的 y
次幂。 示例:
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Pow(2, 1)) // 2
fmt.Println(math.Pow(2, 5)) // 32
}
Sqrt 函数
Sqrt(x float64) float64
:对 x
开平方。 示例:
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Sqrt(64)) // 8
fmt.Println(math.Sqrt(16)) // 4
}
Cbrt 函数
Cbrt(x float64) float64
:对 x
开立方。 示例:
import (
"fmt"
"math"
)
func main() {
fmt.Println(math.Cbrt(64)) // 4
fmt.Println(math.Cbrt(8)) // 2
}
Modf 函数
Modf(f float64) (int float64, frac float64)
:分别取出 f
的整数部分和小数部分。
int
参数,整数部分。frac
参数,小数部分。 示例:
import (
"fmt"
"math"
)
func main() {
integer, decimal := math.Modf(3.1415)
fmt.Printf("整数部分:%.f 小数部分:%.4f", integer, decimal) // 整数部分:3 小数部分:0.1415
}
rand
rand
标准库提供了多个获取不同类型随机数的函数。
常用函数
函数 | 说明 |
---|---|
Int() int | 返回一个 int 类型的非负的伪随机数 |
Intn(n int) int | 返回一个 0 到 n 中(不包括 n)的 int 类型的非负伪随机数 |
Int31() int32 | 返回一个 int32 类型的非负的伪随机数 |
Uint32() uint32 | 返回一个 uint32 类型的非负的伪随机数 |
Int31n(n int32) int32 | 返回一个 0 到 n 中(不包括 n)的 int32 类型的非负伪随机数 |
Int63() int64 | 返回一个 int64 类型的非负的伪随机数 |
Uint64() uint64 | 返回一个 uint64 类型的非负的伪随机数 |
Int63n(n int64) int64 | 返回一个 0 到 n 中(不包括 n)的 int64 类型的非负伪随机数 |
Float32() float32 | 返回一个 0.0 到 1.0 中(不包括 1.0)的 float32 类型的非负伪随机数 |
Float64() float64 | 返回一个 0.0 到 1.0 中(不包括 1.0)的 float64 类型的非负伪随机数 |
Seed(seed int64) | 设置随机种子,使得每次获取随机数的值都不一样 |
如果想了解更多函数介绍和使用,可以到 pkg.go.dev/math/rand 进行查看。
代码示例
import (
"fmt"
"math/rand"
)
func main() {
fmt.Println(rand.Int()) // 5577006791947779410
fmt.Println(rand.Intn(10)) // 7
fmt.Println(rand.Int31()) // 1427131847
fmt.Println(rand.Uint32()) // 1879968118
fmt.Println(rand.Int31n(10)) // 1
fmt.Println(rand.Int63()) // 6334824724549167320
fmt.Println(rand.Uint64()) // 9828766684487745566
fmt.Println(rand.Int63n(10)) // 8
fmt.Println(rand.Float32()) // 0.09696952
fmt.Println(rand.Float64()) // 0.30091186058528707
}
多次运行上述代码,发现获取到的随机数都是一样的,这是因为我们没有设置随机种子。可以通过 Seed
函数进行设置:
import (
"fmt"
"math/rand"
"time"
)
func main() {
rand.Seed(time.Now().Unix())
fmt.Println(rand.Intn(10))
}
使用 Seed
函数设置随机种子,将当前时间的秒数作为参数。后续多次获取随机数的值将不会一直一样。
小结
本文介绍了标准库 math
和 rand
的常用函数的用法,并通过例子进行说明。
math
库里虽说有最大值和最小值比较,但是形参类型必须是浮点型,如果我们想比较的是整型的最大最小值,就得自己封装函数。
获取随机数时,不要忘记设置随机种子,否则多次获取到的随机数将会是一样的。
来源:https://juejin.cn/post/7177775332194254885
猜你喜欢
- 1.Airbus Ship Detection Challengeurl: https://www.kaggle.com/comp
- 1.语法及用法(1)语法:str.endswith(suffix[,start][,end])str:字符串,待判断字符串suffix:后缀
- ORA-00600:internal error code,arguments:[num],[?],[?],[?],[?]产生原因:这种错误
- 引子上下文管理器是一种简化代码的有力方式,其内部也蕴含了很多Python的编程思想,今天我们就来探究一下Python的上下文管理器。大家之前
- Server对象主要是给编程人员提供一些方便的对象和属性。(1)ScriptTimeout属性:<%Server.ScriptTime
- 因为有个老Yashica相机机身,前一阵忍不住想配几个标准镜头。到国内购物网站以及摄影器材交流论坛上看了看,发现不仅很少,价格不实在,而且品
- 前言大家好最近python爬虫有点火啊,啥python爬取马保国视频……我也来凑个热闹,今天我们来试着做个翻译软件……不是不是,说错了,今天
- 前言本文主要介绍的是用yum安装MySQLdb模块的步骤,下面话不多说了,来看看详细的介绍吧。步骤如下MySQLdb依赖于mysql-dev
- 为了获取ROC曲线的最佳阈值,需要使用一个指标--约登指数,也称正确指数。借助于matlab的roc函数可以得出计算。% 1-specifi
- 如果你在文件夹里有很多视频,并且文件夹里还有文件夹,文件夹里的文件夹也有视频,怎么能逐个读取并且保存。。所以我写了个代码用了os,walk,
- 1、程序执行代码:#Author by Andy#_*_ coding:utf-8 _*_import os,sys,timeBase_di
- 以下是一个类文件,下面的注解是调用类的方法注意:如果系统不支持建立Scripting.FileSystemObject对象,那么数据库压缩功
- 本文实例讲述了Python实现的本地文件搜索功能。分享给大家供大家参考,具体如下:偶尔需要搜索指定文件,不想每次都在windows下面去搜索
- 在select语句中可以使用groupby子句将行划分成较小的组,然后,使用聚组函数返回每一个组的汇总信息,另外,可以使用having子句限
- 使用threading.Event可以实现线程间相互通信,之前的Python:使用threading模块实现多线程编程七[使用Conditi
- 如何创建一个Python工程并使其具有Pycharm的代码风格,具体如下1、主题这部分教程主要介绍如何创建一个Python工程并使其具有Py
- 一、创建一个线程通过实例化threading.Thread类创建线程import threadingdef func(s):print(s)
- ThinkPHP模板的empty标签用于判断模板变量是否为空值。ThinkPHP模板empty标签用来判断模板变量是否为空值,其功能相当于P
- 前言有时候字符串匹配解决不了问题,这个时候就需要正则表达式来处理。因为每一次匹配(比如找以什么开头的,以什么结尾的字符串要写好多个函数)都要
- 加载垃圾邮件数据集spambase.csv(数据集基本信息:样本数: 4601,特征数量: 57, 类别:1 为垃圾邮件,0 为