跟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 类型的范围。如果超出范围,则输出提示信息;否则才进行转换。

相关推荐
Q***f6352 分钟前
Kotlin在Android性能优化中的工具
android·开发语言·kotlin
菠菠萝宝33 分钟前
【Java手搓RAGFlow】-9- RAG对话实现
java·开发语言·人工智能·llm·jenkins·openai
leon_zeng034 分钟前
Qt OpenGL 3D 彩色立方体开发指南
开发语言·qt
小猪佩奇TONY1 小时前
OpenGL-ES 学习(16) ----Pixel Buffer Object
服务器·学习·elasticsearch
科威舟的代码笔记1 小时前
第10讲:Stream实战与陷阱——综合案例与最佳实践
java·开发语言
石像鬼₧魂石1 小时前
有哪些常见的字典可以用于Hydra的密码破解?
linux·学习·ssh
MM_MS1 小时前
WinForm+C#小案例--->爱心跑马灯演示
开发语言·c#·visual studio
福尔摩斯张1 小时前
C语言核心:string函数族处理与递归实战
c语言·开发语言·数据结构·c++·算法·c#
程序定小飞1 小时前
基于springboot的体育馆使用预约平台的设计与实现
java·开发语言·spring boot·后端·spring
大佬,救命!!!1 小时前
最新的python3.14版本下仿真环境配置深度学习机器学习相关
开发语言·人工智能·python·深度学习·机器学习·学习笔记·环境配置