rxjava的observable订阅时如何实现oncomplete取消订阅
使用rxjava 2.x时,要在oncomplete被调用时取消订阅,可以使用completablefuture.complete向调用方发送完成信号。
示例:
flowable由持久层方法返回,以下是调用方中的代码:
... private volatile completablefuture<string> future = new completablefuture<>(); private atomicinteger count = new atomicinteger(0); @override public disposable flush(information information, flowable<table> table) throws schemaexportexception { logger.info("start flowable flush"); disposable export_flush_complete = table.subscribe(tableins -> { system.out.println(printasciitable(tableins)); system.out.println(printasciicolumns(tableins.getcolumns())); system.out.println("rn"); count.addandget(1); }, throwable -> { logger.debug("export break, reason: " + throwable.getmessage()); future.cancel(true); throw new schemaexportexception(throwable); }, new action() { @override public void run() throws exception { logger.debug("export complete, affect size:" + count.get()); future.complete("ok"); } }); return export_flush_complete; } ...
调用方的代码:
... long startStamp = System.currentTimeMillis(); // Flowable Flowable<Table> tableFlowable = result.getAll(dbName.get(), strategy).flatMap(new Function<Table, Publisher<Table>>() { @Override public Publisher<Table> apply(@NonNull Table table) throws Exception { return result.getTableColumn(table).flatMap(new Function<List<Column>, SingleSource<Table>>() { @Override public SingleSource<Table> apply(@NonNull List<Column> columns) throws Exception { return Single.just(table.fillColumn(columns)); } }).flatMapPublisher(new Function<Table, Publisher<? extends Table>>() { @Override public Publisher<? extends Table> apply(@NonNull Table table) throws Exception { return Flowable.just(table); } }); } }); Disposable disposable = null; try { disposable = out.flush(info, tableFlowable); CompletableFuture<String> future = out.getFuture(); while (!future.isDone()) { logger.info("[ERE-Flowable]未完成,线程休眠1秒"); Thread.currentThread().sleep(1000, 0); } String result = future.get(); logger.info("[ERE-Flowable]完成, 结果:" + result); if (result.equals("OK")) { long finishStamp = System.currentTimeMillis(); clearHander(disposable, "[ERE-Flowable]RxJava disposed because complete, WithTime: " + (finishStamp - startStamp)); } } catch (Exception e) { clearHander(disposable, "[ERE-Flowable]RxJava disposed has Exception: " + e.getMessage()); } ...
如何编写和贡献Java框架文档和教程?
为什么 Java 函数在高负载下会出现执行效率降低?
理解Java中的float和double
Finalize() 方法
Java DES加密后,如何用PHP解密?
在配置自定义线程池时,如果没有调用`initialize()`方法,程序仍然可以正常运行的原因可能有以下几种: 1. **自动初始化**:某些线程池实现可能在首次使用时自动进行初始化。在这种情况下,即使你没有显式调用`initialize()`方法,线程池也会在需要时自动初始化。 2. **延迟初始化**:有些线程池设计支持延迟初始化,即在第一次提交任务时才进行初始化。如果你的代码在使用线程池之前没有显式调用`initialize()`方法,但随后提交了任务,那么线程池可能会在提交任务时自动初始化。