gpt4 book ai didi

java - 在将某些内容馈送到管道 STDIN 之前,无法跟踪以管道 STDOUT 为食的运行进程

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:43:28 25 4
gpt4 key购买 nike

我正在尝试在正在运行的 Java 程序和控制台之间实现基于命名 PIPE 的进程间通信。 java程序(Test.java)的内容是:

import java.io.*;

public class Test {
public static void main(String[] args) throws Exception {
// starts pipe server
InputStreamReader isReader = new InputStreamReader(System.in);
BufferedReader bufReader = new BufferedReader(isReader);
boolean shutdown = false;
while(!shutdown) {
String inputStr = bufReader.readLine();
if(inputStr != null) {
System.out.println("PONG: "+inputStr);
}
Thread.sleep(1000);
}
}
}

程序编译使用:

javac Test.java

已创建命名管道:

mkfifo testing

然后程序作为管道 STDOUT 的消费者运行:

java Test < testing

然后,我使用控制台向管道 STDIN 发送 ping:

echo PING > testing

由java程序捕获,输出:

PONG: PING

现在出现奇怪的问题:无论何时运行 java 程序,直到消息发送到管道,使用 ps eaux 无法跟踪其进程甚至在 /proc/ 中。

这在 ubuntu(工作计算机)和 rhel(生产服务器)操作系统上重现。有谁知道为什么会这样?

最佳答案

这与您的 java 程序无关,但与您启动它的 shell 以及命名管道的行为有关。

在类似 program <file 的命令中, shell 将首先 fork()一个单独的进程,然后通过 open() 执行重定向荷兰国际集团file ,最后 execve() program .

如果file是命名管道/fifo,open()它将阻塞直到它的另一端也被打开。从那里你观察到的行为,你的java程序直到你open()才开始。 fifo 的另一端。

您可以通过以读/写模式打开 fifo 轻松解决这个问题,这不会阻塞,但这意味着放弃检测读取器何时关闭其管道末端的能力——您的程序永远不会得到一个EOF在其标准输入上:

mkfifo testing
java Test 0<>testing

关于java - 在将某些内容馈送到管道 STDIN 之前,无法跟踪以管道 STDOUT 为食的运行进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57240633/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com