理解 Go 中的除法
与其他自动执行浮点除法的编程语言不同,Go 需要显式转换为浮点除法运营。使用整数时,这可能会导致意外结果。
请考虑以下代码:
fmt.Println(3 / 10)
这将输出 0 而不是预期的 0.3。原因是操作数 3 和 10 都是无类型整型常量。根据Go语言规范,如果二元运算的操作数是不同种类的无类型常量,则运算和结果使用列表中后面出现的类型:整数、符文、浮点、复数。在这种情况下,整数出现在浮点之前,因此结果是无类型整数 (0)。
要获得浮点结果,操作数之一必须是浮点常量。考虑以下情况:
fmt.Println(3.0 / 10.0) fmt.Println(3.0 / 10) fmt.Println(3 / 10.0)
所有这些表达式的计算结果将是无类型浮点常量 0.3。通过向任一操作数添加 .0,我们将其显式转换为浮点,从而得到浮点结果。
当除法运算涉及类型化操作数时,类型化操作数的类型决定了表达式的类型。为了确保 float64 结果,类型化操作数应该是 float64。例如:
var i3 = 3 var i10 = 10 fmt.Println(float64(i3) / 10) fmt.Println(3 / float64(i10))
这些表达式会将 int 变量转换为 float64,从而产生 0.3 的 float64 结果。
需要注意的是,像 10.0 和 3.0 这样的数字文字是无类型浮点数-point 常量,而不是 float64。像 i3 / 10.0 和 3.0 / i10 这样的表达式仍然会产生整数 0,因为类型化操作数(i3 和 i10)决定了结果的类型。
以上是Go 如何处理整数除法,如何确保浮点结果?的详细内容。更多信息请关注PHP中文网其他相关文章!

OpenSSL,作为广泛应用于安全通信的开源库,提供了加密算法、密钥和证书管理等功能。然而,其历史版本中存在一些已知安全漏洞,其中一些危害极大。本文将重点介绍Debian系统中OpenSSL的常见漏洞及应对措施。DebianOpenSSL已知漏洞:OpenSSL曾出现过多个严重漏洞,例如:心脏出血漏洞(CVE-2014-0160):该漏洞影响OpenSSL1.0.1至1.0.1f以及1.0.2至1.0.2beta版本。攻击者可利用此漏洞未经授权读取服务器上的敏感信息,包括加密密钥等。

本文演示了创建模拟和存根进行单元测试。 它强调使用接口,提供模拟实现的示例,并讨论最佳实践,例如保持模拟集中并使用断言库。 文章

本文探讨了GO的仿制药自定义类型约束。 它详细介绍了界面如何定义通用功能的最低类型要求,从而改善了类型的安全性和代码可重复使用性。 本文还讨论了局限性和最佳实践

本文讨论了GO的反思软件包,用于运行时操作代码,对序列化,通用编程等有益。它警告性能成本,例如较慢的执行和更高的内存使用,建议明智的使用和最佳

本文使用跟踪工具探讨了GO应用程序执行流。 它讨论了手册和自动仪器技术,比较诸如Jaeger,Zipkin和Opentelemetry之类的工具,并突出显示有效的数据可视化

本文讨论了GO中使用表驱动的测试,该方法使用测试用例表来测试具有多个输入和结果的功能。它突出了诸如提高的可读性,降低重复,可伸缩性,一致性和A


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

禅工作室 13.0.1
功能强大的PHP集成开发环境

Atom编辑器mac版下载
最流行的的开源编辑器

SublimeText3汉化版
中文版,非常好用