- Java锁的逻辑(结合对象头和ObjectMonitor)
- 还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
- 自动注册实体类到EntityFrameworkCore上下文,并适配ABP及ABPVNext
- 基于Sklearn机器学习代码实战
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())
}
其他常用数学常量还有:
参考: https://golang.google.cn/pkg/math/ 。
最后此篇关于math库中常用的数学运算和常量【GO基础】的文章就讲到这里了,如果你想了解更多关于math库中常用的数学运算和常量【GO基础】的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我试图为此搜索答案,但我发现很难找到这种“确切”的例子。我对指向指针的指针知之甚少,我觉得除了指向某物的指针之外,还有更多东西隐藏在它的表层之下。 那么你们会如何翻译呢? void free(sham
我有一个类的属性,比如const CFoo &bar() const,这是什么意思? 最佳答案 bar 方法返回对 const CFoo 的引用(即 bar 之前的 const CFoo & 部分),
例如是 int const x = 3; 有效代码? 如果是的话,意思是一样的 const int x = 3; ? 最佳答案 它们都是有效的代码并且它们都是等价的。对于指针类型,尽管它们都是有效代码
我知道 f(const T& obj) // (1) g(T const& obj) // (2) 是一样的。(我们不能改变f和g中obj的值)。 但是什么 h(T & const) // (3) 真
本节讲解的内容 include和include_once require和require_once 常量 引入文件和常量结合案列 变量操作函数 输出语句 前言 在上篇文章中,我们讨论了函数的应用,但是
我们知道我们可以保护变量的值,因此用户无法更改现有变量的值!这对对象来说没有什么问题吗?? 例如.. const x = 5; x = 10; alert(x) // will be returned
我正准备为 CUDA 设备编写直方图内核。它基于 NVIDIA's paper . 这个想法是每个线程计算某个部分(在我的例子中是体积)的部分直方图并将其写入共享内存块。然而,我遇到了一个奇怪的算法问
常量是固定值,程序执行期间不会改变。常量可以是任何基本数据类型,比如整数常量、浮点常量、字符常量或者字符串常量,还有枚举常量。 常量可以被当作常规的变量,只是它们的值在定义后不能被修改。 整数常
在这种情况下,如何识别是否有变量或字面量传递给函数 f()? 如何实现passed_as_constant()检查(见下面代码)? sub f { my $refStr=\$_[0]; ret
我目前想知道如何在 python 中列出 win32com 中的常量, 例如使用 excel win32com.client.Dispatch('Excel.Application') 有没有办法使用
这个问题在这里已经有了答案: PHP | define() vs. const (9 个回答) 关闭8年前。 在 PHP 中遇到常量问题想知道是否有人可以解释: 这行得通 const _ROOT =
我正在学习 Rust,到目前为止,似乎有 3 种声明变量的方法: const A: u8 = 42; static A: u8 = 42; let A: u8 = 42; 我知道你不能有一个可变的 c
我正在使用函数模板 void _createAttr(T)(args..., in T[]) 并使用 测试 T 的类型函数中的 static if(is(T == char)) 。当我打电话时, _c
这可能是一个天真的问题,我怀疑答案是"is",但我没有运气在这里和其他地方搜索“erlang编译器优化常量”等术语。无论如何,erlang 编译器是否可以(将)在编译时创建一个常量或文字的数据结构,并
我刚遇到这段 Java 脚本代码: const { myKey, uname, issorted, title, hClick, } = this.props; 请告诉我这是什么意
我正在努力实现以下目标: 我有一个父类,有一些逻辑。在子类中,我“重新定义”常量/属性。有没有办法让子属性可以通过父类中定义的方法访问?或者更具体地说 - 有什么方法可以强制“out”方法在下面的示例
如果这是个愚蠢的问题,请原谅。 我有一个带有内部类接口(interface)的“fragment ”外部类。该接口(interface)仅由另一个 Activity 类使用“implements Ou
我是 python 新手,尝试使用默认值并为类实例自定义它们。 因此,在这个示例中,我定义了一个 DEFAULT_STRING 和一个 DEFAULT_SETTINGS 变量,可以使用 customi
在 integer.xml 中,其形式为 0x001 0x002 是代码和 xml 文件都需要的存储常量。 C# 识别 Droid.Resource.Integer.foo,但它有一些大的
是否有跨平台(即跨 Linux、BSD 和 OS X,最好是所有 POSIX)我可以纯粹基于字符串 以编程方式访问诸如 O_RDWR 之类的常量>“O_RDWR”?我正在编写一些(非 C)代码,这些代
我是一名优秀的程序员,十分优秀!