我有一个大而古老的 FORTRAN 77 代码,它已经工作了很多年,没有任何问题。双精度已经不够了,所以要转换为四精度,我有:
- 将所有出现的 REAL 8 替换为 REAL 16
- 将 DCOS() 等所有函数替换为 COS() 等函数
- 将所有内置数字替换为 0.d0 到 0.q0 和 1D+01 到 1Q+01
使用 gcc-4.6 编译器编译程序没有错误或警告
- 操作系统:openSUSE 11.3 x86_64(64位操作系统)
- 硬件:Intel Xeon E5-2650 (Sandy Bridge)
我的 LD_LIBRARY_PATH 变量设置为 64 位库文件夹:/gcc-4.6/lib64
程序读取一个包含数字的输入文件。这些数字曾经是 1.234D+02 的形式(适用于代码的双精度版本)。我已经改变了它们,所以现在这个数字是 1.234Q+02 ,但是我得到了运行时错误:
列表输入的第 1 项中的实数错误
表明从输入文件(称为read.f)读取数据的子程序在输入文件中没有找到第一个数字,与预期的兼容。
奇怪的是,当输入文件包含像 1.234D+02 或 123.4 这样的数字时,四精度版本的代码不会抱怨(根据输出,它们似乎自动转换为 1.234D+02 而不是 Q+02 的形式),它只是不喜欢 Q+02 ,因此 gcc-4.6 似乎不允许以科学计数法从输入文件中读取四精度数字!
有没有人能够在 FORTRAN 中使用 gcc 编译器从输入文件中读取科学记数法的四精度数(例如 1234Q+02),如果是,你是如何让它工作的?(或者你需要不同的编译器/操作系统/硬件来让它工作吗?)