【问题标题】:trying to capture javac output in bash shell试图在 bash shell 中捕获 javac 输出
【发布时间】:2008-11-25 15:35:22
【问题描述】:

我正在尝试将 java 编译器输出重定向到一个文件。 我认为它应该是:

javac file.java > log.txt

什么的。相反,我在终端上看到了所有输出,而 log.txt 中什么也没有!

另外,如果我也想记录错误,我会这样做吗

javac file.java 2>&1 > log.txt

?

【问题讨论】:

    标签: bash shell javac


    【解决方案1】:
    javac file.java 2> log.txt
    

    原因是您有 两个 输出文件描述符而不是一个。通常的一个是标准输出,您可以使用 > 重定向它,它应该用于结果输出。第二个,stderr,用于人类可读的输出,如警告、错误、当前状态等,这个用 2> 重定向。

    您的第二行,使用 2>&1,将 stderr 重定向到 stdout,最后将 stdout 重定向到 log.txt。

    【讨论】:

    • 我看到重定向 stderr 给了我想要的输出。为什么所有内容都记录在stderr中而stdout中什么都没有?另外,你能告诉我为什么 javac file.java 2>&1 > log.txt 不起作用吗?
    • 重定向是从左到右处理的。 2>&1 将 stderr 发送到 stdout 当前所在的位置 - 终端。然后 >log.txt 将标准输出发送到 log.txt,让标准错误写入原始标准输出。如果你写了>log.txt 2>&1,那么所有的输出都会到文件中。
    • 如果您知道这也有效,您将获得奖励积分:>log.txt javac 2>&1 file.java
    • stdout 与 stderr 的“哲学”是如果出现问题,“cmd >foo.txt”应该向终端写入一些内容。 javac 遵循这条规则,因为它的所有输出都是“出错了”。
    【解决方案2】:

    你试过了吗

    javac -Xstdout log.txt file.java
    

    这会将编译器错误发送到日志文件而不是标准错误。

    【讨论】:

      猜你喜欢
      • 2015-05-08
      • 1970-01-01
      • 1970-01-01
      • 2015-01-19
      • 1970-01-01
      • 2018-07-07
      • 1970-01-01
      • 2023-04-07
      • 1970-01-01
      相关资源
      最近更新 更多