【发布时间】:2016-10-18 20:33:22
【问题描述】:
我需要执行一个 Java 方法最多 X 秒。 如果方法的代码在 X 秒后没有终止,我需要继续执行。
我尝试使用以下代码(使用 ExecutorService 类)。
private void execLoop(){
ExecutorService executor = Executors.newSingleThreadExecutor();
int iteration;
for(iteration=0;iteration<10;iteration++) {
CallableTask ct = new CallableTask();
Future<String> future = executor.submit(ct);
try {
future.get(5, TimeUnit.SECONDS);
} catch (InterruptedException e) {
e.printStackTrace();
} catch (ExecutionException e) {
e.printStackTrace();
} catch (TimeoutException e) {
e.printStackTrace();
}
}
}
class CallableTask implements Callable {
@Override
public Object call() throws Exception {
Log.d("TIME","executed!");
int t=0;
boolean c = true;
while(c){
t+=0; // infinite loop: this method will never terminate
}
return null;
}
}
我对这段代码的期望是每 5 秒向 logcat 打印一次字符串“已执行!” 10次。 但是,执行陷入了无限循环。
【问题讨论】: