码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Golang小数点保留


    小数点保留的计算方式与性能

    案例

    • 计算π保留15位小数
    • 三种计算方式代码
      //第1种
      result := math.Round(pi*1e15) / 1e15
      //第2种
      result, _ := strconv.ParseFloat(strconv.FormatFloat(pi, 'f', 15, 64), 64)
      //第3种
      result,_ := strconv.ParseFloat(fmt.Sprintf("%.15f", pi), 64)
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6

    结论

    • 循环计算1千万次,第一种方法耗时最少

    • 耗时表

      方法耗时
      第1种6
      第2种4650
      第3种5708

    引申问题

    • 会不会超过int64的大数导致计算溢出
      maxint64值为9223372036854775807使用值 922337203685477580.1234567890进行计算结果正确
    • 为什么结果争取
      在go内部使用IEEE-754标准方式存储小数。不在此处详细介绍,大家可自行搜索

    性能测试机器信息

    • 2014年老mac笔记本

    性能测试方法

    • 代码
      //TestDecimalPlacesPerformance 小数保留性能测试
      func TestDecimalPlacesPerformance(t *testing.T) {
      
      	max := 922337203685477580.1234567890
      	fmt.Printf("%v\n", max*11 )
      
      	pi := math.Pi
      
      	//第1种方式功能测试
      	b1 := math.Round(pi*1e15) / 1e15
      	fmt.Printf("结果1  :%v\n", b1)
      
      	//第2种方式功能测试
      	b2, _ := strconv.ParseFloat(strconv.FormatFloat(pi, 'f', 15, 64), 64)
      	fmt.Printf("结果2  :%v\n", b2)
      
      	//第3种方式功能测试
      	b3, _ := strconv.ParseFloat(fmt.Sprintf("%.15f", pi), 64)
      	fmt.Printf("结果3  :%v\n", b3)
      
      	fmt.Printf("----------------------------------------------------------------------\n")
      
      	//循环次数
      	testTimes := int(1e7)
      
      	//第1种方式耗时
      	startTime := time.Now().UnixNano() / 1e6
      	for i := 0; i < testTimes; i++ {
      		_ = math.Round(pi*1e15) / 1e15
      	}
      	fmt.Printf("耗时1  :%v\n", time.Now().UnixNano()/1e6-startTime)
      
      	//第2种方式耗时
      	startTime = time.Now().UnixNano() / 1e6
      	for i := 0; i < testTimes; i++ {
      		_, _ = strconv.ParseFloat(strconv.FormatFloat(pi, 'f', 15, 64), 64)
      	}
      	fmt.Printf("耗时2  :%v\n", time.Now().UnixNano()/1e6-startTime)
      
      	//第3种方式耗时
      	startTime = time.Now().UnixNano() / 1e6
      	for i := 0; i < testTimes; i++ {
      		_,_ = strconv.ParseFloat(fmt.Sprintf("%.15f", pi), 64)
      	}
      	fmt.Printf("耗时3  :%v\n", time.Now().UnixNano()/1e6-startTime)
      }
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14
      • 15
      • 16
      • 17
      • 18
      • 19
      • 20
      • 21
      • 22
      • 23
      • 24
      • 25
      • 26
      • 27
      • 28
      • 29
      • 30
      • 31
      • 32
      • 33
      • 34
      • 35
      • 36
      • 37
      • 38
      • 39
      • 40
      • 41
      • 42
      • 43
      • 44
      • 45
      • 46
  • 相关阅读:
    基于微信小程序的“共享书角”图书借还管理系统(springboot+vue)
    在线副业教程之 01 如何通过编码赚钱的 6 种方法
    QT6.6下android编译及调用自定义so库方法
    漂亮的bootstrap后台模板
    【运筹优化】结合天际线启发式的蚁群算法求解二维矩形装箱问题 + Java代码实现
    java-net-php-python-springboot药膳食疗系统计算机毕业设计程序
    Fiddler 系列教程(二) Composer创建和发送HTTP Request跟手机抓包
    New PMC 田原: 开源给了我一个接触非业务系统的机会
    【linux多线程】查看进程的所有线程/活跃线程
    Delphi Modbus RTU CRC16校验码的生成方式
  • 原文地址:https://blog.csdn.net/xiao44_java/article/details/126093434
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号