java – Runtime.getRunTime().exec的行为与C语言“system()”命令不同

  

在“C”中,我可以在启动过程退出后在后台运行一个长时间的阻塞过程(并且它已经继续运行).

void main(void)
{
      system("some_long_blocking_process &");
      exit();
}

// "some_long_blocking_process" is still running here (DESIRED BEHAVIOR)

Java的getRuntime().exec()没有这种行为.相反,“some_long_blocking_process”在Java进程结束时立即结束.

任何人都知道如何在Java中重新捕获这种行为?

>我使用的是Java 1.4(无流程构建器)
>我特别希望启动长阻塞过程并立即退出(没有“waitFor()等”)
>我已经尝试过的事情(过程运行正常,但我仍然得到相同的不良行为)

>添加“nohup”并在前台运行(“nohup some_long_process”)
>添加“nohup”并在后台运行(“nohup some_long_process&”)
>在前台运行(“some_long_process”)
>在后台运行(“some_long_process&”)

谢谢!

感谢所有的建议…我决定使用jtahlborn的答案(它对我有用)

解决方法:

我们用java实现这一目标的唯一方法是添加另一层脚本.你需要一个简单的包装器脚本来调用你真正想要运行的应用程序,例如:

runner.sh:

#!/bin/sh

nohup "$@" > /dev/null 2>&1 &

然后从你的java程序中调用“/ bin / sh runner.sh the real command”.

相关文章