我正在尝试实现一个代码,我想从JNI调用一个应该有超时的函数。如果超过超时,我想终止本机任务。我发布了一段代码作为示例。
void myFunction(timeOutInSeconds)
{
if(timeOutInSeconds > 0)
{
ExecutorService executor = Executors.newCachedThreadPool();
Callable<Integer> task = new Callable<Integer>() {
public Integer call() {
System.out.println("Calling JNI Task");
JNI_Task();
System.out.println("Finished JNI Task");
return 0;
}
};
Future<Integer> future = executor.submit(task);
try
{
@SuppressWarnings("unused")
Integer result = future.get(timeOutInSeconds, TimeUnit.SECONDS);
}
catch (TimeoutException ex)
{
// handle the timeout
kill_task_in_JNI();
// future.cancel(true);
return TIMEOUT;
} catch (InterruptedException e) {
// handle the interrupts
} catch (ExecutionException e) {
// handle other exceptions
}
finally
{
// future.cancel(true);
executor.shutdown();
}
}
else
JNI_Task();
}
有几个问题 -
这种方法有问题吗?
答案 0 :(得分:2)
你可以(在这种情况下应该)只在finally块中调用future.cancel()
。 http://docs.oracle.com/javase/tutorial/essential/exceptions/finally.html。
关于第二个问题,如果timeOutInSeconds = 0时问题也出现,我不清楚。是这样的吗?你能提供JNI_TASK()方法的内容吗?