加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – “1.0f”和“1.f”之间有什么区别?

发布时间:2020-12-16 03:22:36 所属栏目:百科 来源:网络整理
导读:作为约翰·卡马克(John Carmack)的崇拜者,我正在阅读Id Tech公开提供的编码公约文档(如果您有兴趣,请在 ftp://ftp.idsoftware.com/idstuff/doom3/source/CodeStyleConventions.doc),并发现我不完全明白的约定: Use precision specification for floating po
作为约翰·卡马克(John Carmack)的崇拜者,我正在阅读Id Tech公开提供的编码公约文档(如果您有兴趣,请在 ftp://ftp.idsoftware.com/idstuff/doom3/source/CodeStyleConventions.doc),并发现我不完全明白的约定:

Use precision specification for floating point values unless there is an explicit need for a double.

float f = 0.5f

Instead of

float f = 0.5;

And

float f = 1.0f;

Instead of

float f = 1.f;

这些有什么不同?

我可以理解第一个例子中的两者之间的区别(后者在引擎盖下进行了双向浮点转换),尽管我怀疑它只需要一个不笨的编译器来捕获并生成相同的字节码,因为没有运行时差异.

但是有没有添加尾随0的浮点值声明更改的情况?

解决方法

But is there any case where adding trailing 0’s to your floating point value declaration changes things?

添加零的唯一“事情”会改变是可读性.结果代码将是完全一样的,因为编译器不在乎,但在零位置的常数将更容易被人类读者阅读.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读