我试图让程序运行一些可执行程序(称为p
),给定时间限制t
毫秒。它执行以下任务:从具有时间限制的程序执行程序(Java)
- 如果程序
p
已正常执行,则将其输出到控制台。 - 如果程序
p
无法在时间限制内完全执行,请打印"Sorry, needs more time!"
,然后终止执行p
。 - 如果程序
p
异常终止(例如RuntimeError
),打印"Can I've some debugger?"
我使用ProcessResultReader
类在下面的程序从here。我的程序正在工作,只要p
完成正常执行或终止异常。但是,如果p
本身在timeout
之后没有终止,则它不终止(尝试p
并且没有退出条件的简单while(true)
循环)。看起来线程stdout
即使在执行stdout.stop()
后仍然存在。我在这段代码中做错了什么?
谢谢。
import java.util.concurrent.TimeUnit;
import java.io.*;
class ProcessResultReader extends Thread
{
final InputStream is;
final StringBuilder sb;
ProcessResultReader(final InputStream is)
{
this.is = is;
this.sb = new StringBuilder();
}
public void run()
{
try
{
final InputStreamReader isr = new InputStreamReader(is);
final BufferedReader br = new BufferedReader(isr);
String line = null;
while ((line = br.readLine()) != null)
{
this.sb.append(line).append("\n");
}
}
catch (final IOException ioe)
{
System.err.println(ioe.getMessage());
throw new RuntimeException(ioe);
}
}
@Override
public String toString()
{
return this.sb.toString();
}
public static void main(String[] args) throws Exception
{
int t = 1000;
Process p = Runtime.getRuntime().exec(cmd); //cmd is command to execute program p
ProcessResultReader stdout = new ProcessResultReader(p.getInputStream());
stdout.start();
if(!p.waitFor(t, TimeUnit.MILLISECONDS))
{
stdout.stop();
p.destroy();
System.out.println("Sorry, needs more time!");
}
else
{
if(p.exitValue()==0) System.out.println(stdout.toString());
else System.out.println("Can I've some debugger?");
}
}
}
我知道[this](http://stackoverflow.com/a/2733370/1858327)不完全是你要找的,但它似乎可以帮助或至少指出你在正确的方向。 –