Go语言通过math包提供丰富的数学函数,支持float64类型及IEEE 754标准,涵盖基础运算、三角函数、对数指数、浮点处理等,常用函数包括Abs、Max、Min、Pow、Sqrt、Sin、Cos、Log、Exp、Floor、Ceil等,结合math.Pi与弧度转换可完成常见计算,注意参数范围与特殊值处理即可满足大多数数值计算需求。

Go语言通过标准库中的math包提供了丰富的数学计算功能,涵盖了基本运算、三角函数、对数指数、浮点数处理等多个方面。使用math包可以满足大多数数值计算需求,无需引入第三方库。
导入math包并了解其作用范围
math包仅支持float64类型作为参数和返回值,部分函数也提供float32版本(如math.Frexp)。在使用前需导入:
所有函数均基于IEEE 754浮点数标准实现,注意处理特殊值如NaN、+Inf、-Inf和±0。
常用基础数学函数
基础运算包括绝对值、最大最小值、幂运算与开方等:
立即学习“go语言免费学习笔记(深入)”;
-
math.Abs(x):返回x的绝对值 -
math.Max(x, y)和math.Min(x, y):比较两个数的大小 -
math.Pow(x, y):计算x的y次方 -
math.Sqrt(x):求x的平方根,负数输入返回NaN -
math.Cbrt(x):计算立方根 -
math.Hypot(x, y):计算直角三角形斜边长度,即√(x²+y²),避免溢出
三角函数与反三角函数
所有角度以弧度为单位,需自行转换度与弧度:
PHP是一种功能强大的网络程序设计语言,而且易学易用,移植性和可扩展性也都非常优秀,本书将为读者详细介绍PHP编程。 全书分为预备篇、开始篇和加速篇三大部分,共9章。预备篇主要介绍一些学习PHP语言的预备知识以及PHP运行平台的架设;开始篇则较为详细地向读者介绍PKP语言的基本语法和常用函数,以及用PHP如何对MySQL数据库进行操作;加速篇则通过对典型实例的介绍来使读者全面掌握PHP。 本书
-
math.Sin(x),math.Cos(x),math.Tan(x):基本三角函数 -
math.Asin(x),math.Acos(x),math.Atan(x):反三角函数,返回弧度值 -
math.Atan2(y, x):根据坐标象限返回正确的角度,常用于向量方向计算 -
math.Pi是常用的常量,表示π值
示例:将30度转为弧度并计算正弦值
angleDeg := 30.0angleRad := angleDeg * math.Pi / 180
result := math.Sin(angleRad) // 约等于0.5
对数与指数运算
支持自然对数、常用对数及指数函数:
-
math.Log(x):自然对数(ln x),x≤0时返回-Inf或NaN -
math.Log10(x):以10为底的对数 -
math.Log2(x):以2为底的对数 -
math.Exp(x):e的x次方 -
math.Log1p(x):计算ln(1+x),当x接近0时更精确 -
math.Expm1(x):计算eˣ-1,适用于小数值提高精度
浮点数操作与舍入函数
处理浮点数精度和分解常用以下函数:
-
math.Floor(x):向下取整 -
math.Ceil(x):向上取整 -
math.Trunc(x):截断小数部分 -
math.Round(x):四舍五入到整数(Go 1.10+) -
math.Mod(x, y):浮点数取模运算 -
math.Dim(x, y):若x>y返回x-y,否则返回0 -
math.Copysign(x, y):返回|x|但带有y的符号
浮点数分解可用:
-
math.Frexp(x):将浮点数分解为尾数和指数(x = mantissa × 2^exp) -
math.Ldexp(mantissa, exp):按指定指数重建浮点数
基本上就这些。掌握math包的核心函数后,日常开发中的数学计算问题基本都能解决。注意传参类型和边界情况即可。









