【发布时间】:2014-09-25 14:21:45
【问题描述】:
用例
假设我们使用 CompletableFuture.runAsync(..) 运行执行,并且在 runnable 中我们有 try-with-resources 块(我们正在使用一些资源,无论发生什么都应该关闭),并且在某些时候执行未完成尝试块我们取消可完成的未来......虽然执行停止了应该关闭的资源没有关闭AutoClosable的close()没有被调用......
问题
这是一个 java 问题还是有办法正确地做到这一点?没有像使用期货(支持中断等)这样的变通办法,如果它的预期行为在不可中断的 CompletableFuture 被取消时应该如何处理类似情况......?
代码
public class AutoClosableResourceTest {
public static class SomeService{
public void connect(){
System.out.println("connect");
}
public Integer disconnect(){
System.out.println("disconnect");
return null;
}
}
public static class AutoClosableResource<T> implements AutoCloseable {
private final T resource;
private final Runnable closeFunction;
private AutoClosableResource(T resource, Runnable closeFunction){
this.resource = resource;
this.closeFunction = closeFunction;
}
public T get(){
return resource;
}
@Override
public void close() throws Exception {
closeFunction.run();
}
}
@Test
public void testTryWithResource() throws InterruptedException {
SomeService service = new SomeService();
CompletableFuture<Void> async = CompletableFuture.runAsync(() -> {
try (AutoClosableResource<SomeService> resource = new AutoClosableResource<>(service, service::disconnect)) {
resource.get().connect();
while (true) {
Thread.sleep(1000);
System.out.println("working...");
}
} catch (Exception e) {
e.printStackTrace();
}
});
Thread.sleep(2500);
async.cancel(true);
Thread.sleep(2500);
}
}
这会产生
connect
working...
working...
working...
working...
如您所见,它不会调用 cancel() 并让资源处于打开状态...
【问题讨论】:
标签: java concurrency java-8 try-with-resources