跟ChatGPT学习go语言-float64转成int

在 Go 语言中可以将 float64 类型转换为 int 类型。需要注意的是,转换过程中会丢失小数部分,只保留整数部分。

示例代码

bash 复制代码
package main

import (
    "fmt"
)

func main() {
    var f float64 = 123.456
    var i int = int(f)
    fmt.Printf("float64: %f, int: %d\n", f, i)
}

解释

1.定义一个 float64 类型的变量 f:

bash 复制代码
var f float64 = 123.456

2.将 float64 转换为 int:

bash 复制代码
var i int = int(f)

这行代码将 f 转换为 int 类型,并赋值给变量 i。转换时会舍弃小数部分,所以 i 的值将是 123。

3.打印结果:

bash 复制代码
fmt.Printf("float64: %f, int: %d\n", f, i)

这行代码将输出:

bash 复制代码
float64: 123.456000, int: 123

注意事项

舍弃小数部分:在转换过程中,小数部分会被舍弃。例如,123.456 会被转换为 123。

溢出风险:如果 float64 的值超出了 int 类型的范围,转换后的结果可能会导致溢出。

处理溢出

如果你需要处理可能的溢出情况,可以在转换前进行检查:

bash 复制代码
package main

import (
    "fmt"
    "math"
)

func main() {
    var f float64 = 1e20 // 一个非常大的浮点数
    if f > float64(math.MaxInt64) || f < float64(math.MinInt64) {
        fmt.Println("Value is out of int range")
    } else {
        var i int = int(f)
        fmt.Printf("float64: %f, int: %d\n", f, i)
    }
}

在这个示例中,首先检查 f 是否超出了 int 类型的范围。如果超出范围,则输出提示信息;否则才进行转换。

相关推荐
傻啦嘿哟24 分钟前
如何在 Python 中使用 colorama 库来给输出添加颜色
开发语言·python
嵌入式小企鹅1 小时前
CPU供需趋紧、DeepSeek V4全链适配、小米开源万亿模型
人工智能·学习·开源·嵌入式·小米·算力·昇腾
geovindu1 小时前
go: Visitor Pattern
开发语言·设计模式·golang·访问者模式
宣宣猪的小花园.1 小时前
C语言重难点全解析:内存管理到位运算
c语言·开发语言·单片机
方安乐5 小时前
python之向量、向量和、向量点积
开发语言·python·numpy
三品吉他手会点灯7 小时前
C语言学习笔记 - 20.C编程预备计算机专业知识 - 变量为什么必须的初始化【重点】
c语言·笔记·学习
sakiko_7 小时前
UIKit学习笔记1-创建项目(使用UIKit)、使用组件
笔记·学习
会编程的土豆7 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
小小小米粒7 小时前
Collection单列集合、Map(Key - Value)双列集合,多继承实现。
java·开发语言·windows
生信碱移7 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言