
本文详解如何在 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 的类型安全特性。