繁体   English   中英

为什么我的 shell 脚本的输出没有在控制台中打印出来?

[英]Why does the output of my shell script doesn't print in console?

我正在尝试使用 java 在控制台上打印 shell 脚本的输出。 当我手动运行脚本时,我得到

C:/Users/user1/Desktop/shell.sh: line 78: /usr/ucb/ps: No such file or directory
<STATUS>: Probe [ devicename ] is not running!

但是,当我尝试在我的 Java 程序上运行它时,输出没有打印在控制台上。 我的代码是:

ProcessBuilder processBuilder = new ProcessBuilder("C:/Program Files/Git/git-bash.exe","C:/Users/user1/Desktop/shell.sh");

try {

    Process process = processBuilder.start();

    StringBuilder output = new StringBuilder();

    BufferedReader reader = new BufferedReader(
            new InputStreamReader(process.getInputStream()));

    String line;
    while ((line = reader.readLine()) != null) {
        output.append(line + "\n");
        System.out.println(line);
    }

    int exitVal = process.waitFor();
    if (exitVal == 0) {
        System.out.println("Success!");
        System.out.println(output);
        System.exit(0);
    } else {
        //abnormal...
    }

} catch (IOException e) {
    e.printStackTrace();
} catch (InterruptedException e) {
    e.printStackTrace();
}

我得到的唯一输出是“成功”。 当我调试我的代码时,我发现代码永远不会进入条件

while ((line = reader.readLine()) != null)

即使在 bash 终端中,也有输出行。 为什么会这样?

我被困在这一点上,我找不到这个问题的任何其他解释。 请帮忙。

您正在运行作为 Windows 应用程序打开的 git-bash.exe。 尽管 Java 可以访问 git-bash.exe 的 stdout/stderr 流,但这些不一定与 git-bash.exe 中 shell 脚本内部启动的 stdout/err 相同。

查看命令的 stdout/err 的一种方法是制作 .sh 脚本的 Java 友好版本,该脚本启动原始 sh 并将输出重定向到特定文件,之后您可以在 Java 中访问这些文件。

ProcessBuilder pb = new ProcessBuilder("C:/Program Files/Git/GIT-BASH.EXE","/c/Users/blah/somescript.sh");

一些脚本.sh:

#!/bin/sh
runtheoriginalcommand > ~/somepath.out 2> ~/somepath.err

您还可以向包装器添加额外的参数以传递要使用的输出/错误文件,这样就不会与任何其他启动或硬编码输出文件争用。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM