Go 语言浮点除法与四舍五入到 4 位小数方法
时间:2026-05-14 16:42:35 202浏览 收藏
本文深入解析了Go语言中浮点除法的常见陷阱与精准控制技巧,重点指出整数相除会默认截断小数导致精度丢失,并手把手教你通过显式转换为float64执行浮点运算,再借助fmt.Printf("%.4f")实现自动四舍五入并稳定输出4位小数(含末尾零),无需依赖math包或手动取整,既简洁又符合Go的类型安全哲学——哪怕只是计算190/13,也能优雅输出准确的14.6154。

本文详解如何在 Go 中正确执行浮点除法,并使用格式化输出将结果精确控制为 4 位小数(自动四舍五入),避免整数除法导致的精度丢失。
本文详解如何在 Go 中正确执行浮点除法,并使用格式化输出将结果精确控制为 4 位小数(自动四舍五入),避免整数除法导致的精度丢失。
在 Go 中,int / int 运算默认执行整数除法,结果直接截断小数部分(非四舍五入),例如 190 / 13 得到 14,而非 14.6153...。这正是原代码输出错误结果的根本原因——即使变量名是 slope,q/w 仍是整型运算,float64(q)/float64(w) 才能触发浮点计算。
要获得带小数的精确商并四舍五入到 4 位,需两个关键步骤:
- 显式类型转换:将整数操作数转为 float64,确保除法按浮点规则执行;
- 格式化输出:使用 fmt.Printf("%.4f", value) 自动完成四舍五入并固定显示 4 位小数(末尾零不省略,如 14.6154)。
以下是修正后的完整可运行代码:
package main
import (
"fmt"
"bufio"
"os"
"strconv"
)
func main() {
var xInp = bufio.NewScanner(os.Stdin)
var yInp = bufio.NewScanner(os.Stdin)
fmt.Print("insert y value: ")
yInp.Scan()
fmt.Print("insert x value: ")
xInp.Scan()
q, err := strconv.Atoi(yInp.Text())
if err != nil {
fmt.Println("error parsing y:", err)
return
}
w, err := strconv.Atoi(xInp.Text())
if err != nil {
fmt.Println("error parsing x:", err)
return
}
// ✅ 关键:转换为 float64 再除法
slope := float64(q) / float64(w)
// ✅ 关键:%.4f 自动四舍五入并保留 4 位小数
fmt.Printf("%.4f\n", slope)
}注意事项:
- 原代码中 err 被重复赋值(q, err := ... 和 w, err := ...),后一次会覆盖前一次错误,应分别检查;示例已添加健壮的错误处理。
- fmt.Printf("%.4f", 14.6153846) 输出 14.6154(第 5 位 8 ≥ 5,进位);%.4f 是标准四舍五入,无需手动调用 math.Round。
- 若需更多精度控制(如向上取整、截断),可结合 math 包(如 math.Round(slope*1e4) / 1e4),但对常规需求,Printf 格式化已足够简洁可靠。
通过这两处修改,程序即可准确输出 190/13 ≈ 14.6154,兼顾精度、可读性与 Go 的类型安全特性。
以上就是《Go 语言浮点除法与四舍五入到 4 位小数方法》的详细内容,更多关于的资料请关注golang学习网公众号!
相关阅读
更多>
-
505 收藏
-
503 收藏
-
502 收藏
-
502 收藏
-
502 收藏
最新阅读
更多>
-
231 收藏
-
344 收藏
-
202 收藏
-
452 收藏
-
173 收藏
-
452 收藏
-
500 收藏
-
277 收藏
-
306 收藏
-
389 收藏
-
112 收藏
-
434 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习