登录
首页 >  Golang >  Go问答

导致数字常量溢出的打印类型

来源:stackoverflow

时间:2024-03-22 09:36:42 428浏览 收藏

在 Go 中,使用无类型常量时,如果该常量超出 int 范围,则在需要 float64 类型时会发生溢出。这是因为无类型常量可以任意大,但当用于 float64 类型时会被截断,而用于 int 类型时会溢出。解决方法是明确将无类型常量转换为所需的类型,例如 float64(常量)。

问题内容

我是 go 新手,目前正在关注go 之旅

我当前位于数字常量页面。下面是该页面上运行的代码的精简版本:

package main
import "fmt"
const big = 1 << 100
func needfloat(x float64) float64 {
    return x * 0.1
}
func main() {
    fmt.println(needfloat(big))
    // fmt.printf("type of big %t", big)
}

此代码编译成功,输出为 1.2676506002282295e+29

但是以下代码不会编译并给出错误:

package main
import "fmt"
const Big = 1 << 100
func needFloat(x float64) float64 {
    return x * 0.1
}
func main() {
    fmt.Println(needFloat(Big))
    fmt.Printf("Type of Big %T", Big)
}

输出: ./prog.go:9:13:常量 1267650600228229401496703205376 溢出 int

您认为为什么会发生这种情况?我希望你能解释一下。


解决方案


常量 Big 是一个无类型常量。无类型常量可以任意大,并且不必符合任何预定义类型的限制。它在使用的上下文中被解释和截断。

函数 needFloat 获取 float64 参数。在本例中,Big 被转换为 float64 并以这种方式使用。

当您将它用于 Printf 时,它会尝试将其作为 int 传入,因为它不是十进制数(否则它会将其转换为 float64),并且会导致溢出。将其作为 float64(Big) 传递,它应该可以工作。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

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