登录
首页 >  Golang >  Go问答

Golang 中的数字计算是否与 JavaScript 中的数字计算有所不同?

来源:stackoverflow

时间:2024-03-23 21:15:28 332浏览 收藏

在 JavaScript 和 Go 语言中,数字计算存在差异。JavaScript 中的数字始终存储为双精度浮点数,遵循 IEEE 754 标准。而 Go 语言中,数字可以表示为不同的类型,例如整数或浮点数。因此,在 Go 语言中进行整数除法时,结果将被截断为整数,而 JavaScript 中的隐式浮点除法则会产生浮点数结果。为了在 Go 语言中获得与 JavaScript 相同的计算结果,需要使用浮点数类型并进行浮点除法。

问题内容

总而言之,我正在尝试将以下 js 代码转换为 go:

5 / 6 * variable * (2 * variable * variable + 27 * variable + 91)

无论我如何尝试,我都无法让它发挥作用。这是针对 discord 机器人的,所以它看起来并不完全像 go。我确信这可以很容易地在一行中完成,而不是多行。

{{ $xpToLvl := (mult $desiredLvl $desiredLvl 2) }}
{{ $xpToLvl = (add $xpToLvl 27 91) }}
{{ $xpToLvl = (mult $desiredLvl $xpToLvl) }}
{{ $xpToLvl = (mult 0.8333333 $xpToLvl) | roundCeil }}

完整代码可以在这里找到。


正确答案


在 javascript 中,数字没有不同的类型,如 int、float、double 等...
javascript 数字始终存储为双精度浮点数,遵循国际 ieee 754 标准。

然而,在 golang 中数字可以用不同的类型表示,如 int、float 等......

因此,

5 / 6 * 变量 * (2 * 变量 * 变量 + 27 * 变量 + 91)

其中 variable 为 17

在 javascript 中
在 javascript 中 5 除以 6(5/6) 将是 0.8333333333333334,因为隐式地它是一个浮点除法(5.0/6.0)

=> 0.8333333333333334 * 17 * ( 2 * 17 * 17 + 27 * 17 + 91 ) => 0.8333333333333334 * 17 * (1128) => 15980.000000000002

在 go 语言中
在 golang 中 5 除以 6(5/6) 将是 0,因为它是整数除法。因此你的表达式的结果是 0。

=> 0 * 17 * ( 2 * 17 * 17 + 27 * 17 + 91 )
=> 0

因此,为了获得与 javascript 中相同的答案,在 golang 代码中使用 float64 数据类型而不是 int。 这是它的样子,

package main

import (
    "fmt"
)

func main() {

    variable := 17.0
    result := 5.0 / 6.0 * variable * (2.0*variable*variable + 27.0*variable + 91.0)
    fmt.Println(result)
}

输出:15980.000000000002

演示:https://play.golang.org/p/xjKarE0Kgnu

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>