作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 Fortran 中使用科学记数法表示浮点文字非常简单:
1.5d-10
意味着 double (无论在当前 Fortran 编译器设置下意味着什么)浮点值,近似于 1.5*10^-15
。
但是,指数表示法和浮点类型说明符的融合有点问题。当希望它具有 C_DOUBLE
类型时,如何声明该浮点文字?
我知道这是一个有点挑剔的问题,但在某些情况下 double 可能与 C_DOUBLE
不同。
最佳答案
真正的文字可以通过以下任何形式指定:
1.2
1.2e0
1.2d0
1.2_kind
1.2e0_kind
最后一个是使用种类说明符和指数的示例。因此,具体到这个问题:1.5e-15_C_DOUBLE
。
当然可能存在 1.5d-15
与 1.5e-15_C_DOUBLE
不同的情况。 double 和 real(C_DOUBLE)
的类型分别由 Fortran 和配套的 C 编译器选择。
允许通过编译器标志将单精度和 double 文字常量提升为更高类型的编译器不会触及 real(C_DOUBLE)
。
对于没有小数部分的实数值,还有其他可用的形式:
1.
1e0
1.e0
1d0
1.d0
1.e0_kind
1e0_kind
也就是说,小数部分是可选的,如果给出指数,则小数分隔符也是可选的。但请注意,1
是整数文字,而 1e0
及类似内容是实数。
关于fortran - Fortran 中的实数同时使用科学记数法和下划线类型说明符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49956241/
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我是一名优秀的程序员,十分优秀!