Fortran 90 中的标准输入和输出单位?
如何在 Fortran 中读取和写入标准输入、输出和错误流 stdin
、stdout
和 stderr
?我听说过写入 stderr
,例如,used 为 write(5, fmt=...)
,使用 5
stderr
的单位,我知道写入 stdout
的方法是使用 write(*, fmt=...)< /代码>。
如何使用 ifort 编译器读取和写入标准输入和输出单元?
编译器版本:
适用于在英特尔(R) 64 上运行的应用程序的英特尔(R) Fortran 编译器,版本 10.0 Build 20070426 软件包 ID:l_fc_p_10.0.023 版权所有 (C) 1985-2007 英特尔公司。保留所有权利
How can I read and write to the standard input, output and error streams stdin
, stdout
and stderr
in Fortran? I've heard writing to stderr
, for example, used to be write(5, fmt=...)
, with 5
the unit for stderr
, and I know the way to write to stdout
is to use write(*, fmt=...)
.
How do I read and write to the standard input and output units with the ifort
compiler?
Compiler version:
Intel(R) Fortran Compiler for applications running on Intel(R) 64, Version 10.0 Build 20070426 Package ID: l_fc_p_10.0.023 Copyright (C) 1985-2007 Intel Corporation. All rights reserved
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
如果您有 Fortran 2003 编译器,则内部模块
iso_fortran_env
定义变量input_unit
、output_unit
和error_unit
分别指向标准输入、标准输出和标准错误。我倾向于
在我的输入/输出例程中使用类似的东西。虽然这当然意味着预处理你的源文件(使用
ifort
,在编译源代码时使用-fpp
标志,或将源文件扩展名从.f
更改为.F
或从.f90 至
.F90
)。另一种方法是编写您自己的非内在
iso_fortran_env
模块(如果您没有 Fortran 2003 编译器),如 此处(此答案发布后此链接已失效)。在此示例中,他们使用一个模块:如其他答案中所述,0、5 和 6 通常是
stderr
、stdin
和stdout
(对于 Linux 上的ifort
来说是这样),但这不是 Fortran 标准定义的。使用 iso_fortran_env 模块是可移植地写入这些单元的正确方法。If you have a Fortran 2003 compiler, the intrinsic module
iso_fortran_env
defines the variablesinput_unit
,output_unit
anderror_unit
which point to standard in, standard out and standard error respectively.I tend to use something like
in my input/output routines. Although this of course means preprocessing your source file (to do this with
ifort
, use the-fpp
flag when compiling your source code or change the source file extension from.f
to.F
or from.f90
to.F90
).An alternative to this would be to write your own, non-intrinsic,
iso_fortran_env
module (if you don't have a Fortran 2003 compiler), as discussed here(this link has died since this answer was posted). In this example they use a module:As noted in other answers, 0, 5 and 6 are usually
stderr
,stdin
andstdout
(this is true forifort
on Linux) but this is not defined by the Fortran standard. Using theiso_fortran_env
module is the correct way to portably write to these units.Fortran 标准没有指定哪些单位编号对应于 stdin/out/err。通常的约定(例如 gfortran)是 stderr=0、stdin=5、stdout=6。
如果您的编译器支持 F2003 ISO_FORTRAN_ENV 内部模块,则该模块包含常量 INPUT_UNIT、OUTPUT_UNIT 和 ERROR_UNIT,允许程序员可移植地检索预连接单元的单元编号。
The Fortran standard doesn't specify which units numbers correspond to stdin/out/err. The usual convention, followed by e.g. gfortran, is that stderr=0, stdin=5, stdout=6.
If your compiler supports the F2003 ISO_FORTRAN_ENV intrinsic module, that module contains the constants INPUT_UNIT, OUTPUT_UNIT, and ERROR_UNIT allowing the programmer to portably retrieve the unit numbers for the preconnected units.
stderr 实际上是 0。 5 是标准输入,6 是标准输出。
例如:
给出:
虽然
我会存储一个 STDERR = 0 的参数以使其可移植,所以如果您遇到不同的平台,您只需更改该参数即可。
此示例是使用 ifort 12.1.1.256、11.1.069、11.1.072 和 11.1.073 编译并运行的。
It's actually 0 for stderr. 5 is stdin, 6 is stdout.
For example:
Gives:
while
I would store a PARAMETER that is STDERR = 0 to make it portable, so if you hit a platform that is different you can just change the parameter.
This example was compiled and run with ifort 12.1.1.256, 11.1.069, 11.1.072 and 11.1.073.
Fortran 中写入
stdout
的标准方法是用星号代替单元号,即,或者简单地使用
类似地,从
stdin
读取的标准方法是除非您使用
ISO_FORTRAN_ENV
模块中的ERROR_UNIT
,否则没有标准方法写入stderr
,这需要 Fortran 2003 或更高版本。单元号 0、5 和 6 肯定可以在 ifort 编译器(以及其他一些 Fortran 编译器)中工作,但请记住它们是依赖于编译器的。
The standard way to write to
stdout
in Fortran is to put an asterisk instead of the unit number, i.e.,or to simply use
Similarly, the standard way to read from
stdin
isThere is no standard way to write to
stderr
unless you useERROR_UNIT
from theISO_FORTRAN_ENV
module, which requires Fortran 2003 or later.Unit numbers 0, 5 and 6 will certainly work in the
ifort
compiler (and also in some other Fortran compilers), but keep in mind they are compiler-dependent.