关于浮点数精度再各个编程语言需要注意点

数据小菜鸟 · · 650 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

浮点数保留N位 (2位),为货币类场景常用选项。比较合理的做法是使用分来存储(int),然后前端在进行转换。否则你就需要关心浮点数自动 四拾伍入。分清自己使用场景选择自己的合适的方法。已知 (mysql(douboule10,2),golang "%.2f",python "%.2f" )

package main

import (
    "fmt"
    "math"
)

func main() {

    //四拾伍入了
    fmt.Printf("%.2f\n", 1.244444)
    fmt.Printf("%.2f\n", 1.245444) 
    
    //自己实现四拾伍入
    fmt.Printf("%.2f\n", math.Trunc(1.244444*1e2+)*1e-2)
    fmt.Printf("%.2f\n", math.Trunc(1.245444*1e2)*1e-2)
    
    //抛弃掉后面位数
    fmt.Printf("%.2f\n", math.Trunc(1.244444*1e2)*1e-2)
    fmt.Printf("%.2f\n", math.Trunc(1.245444*1e2)*1e-2)
}
golang执行结果.png
>>> "%.2f" % 1.24444
'1.24'
>>> "%.2f" % 1.24555
'1.25'

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:数据小菜鸟

查看原文:关于浮点数精度再各个编程语言需要注意点

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

650 次点击  
加入收藏 微博
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传