Skip to content

Commit

Permalink
docs: improve user guide/javadoc 📚
Browse files Browse the repository at this point in the history
  • Loading branch information
oldratlee committed Apr 19, 2024
1 parent 12e03b3 commit b4f93ea
Show file tree
Hide file tree
Showing 6 changed files with 49 additions and 45 deletions.
34 changes: 17 additions & 17 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@
<a href="https://foldright.io/cffu/dokka/"><img src="https://img.shields.io/github/release/foldright/cffu?label=dokka&color=339933&logo=kotlin&logoColor=white" alt="dokka"></a>
<a href="https://central.sonatype.com/artifact/io.foldright/cffu/0.9.0/versions"><img src="https://img.shields.io/maven-central/v/io.foldright/cffu?logo=apache-maven&logoColor=white" alt="Maven Central"></a>
<a href="https://github.com/foldright/cffu/releases"><img src="https://img.shields.io/github/release/foldright/cffu.svg" alt="GitHub Releases"></a>
<a href="https://github.com/foldright/cffu/stargazers"><img src="https://img.shields.io/github/stars/foldright/cffu" alt="GitHub Stars"></a>
<a href="https://github.com/foldright/cffu/fork"><img src="https://img.shields.io/github/forks/foldright/cffu" alt="GitHub Forks"></a>
<a href="https://github.com/foldright/cffu/stargazers"><img src="https://img.shields.io/github/stars/foldright/cffu?style=flat" alt="GitHub Stars"></a>
<a href="https://github.com/foldright/cffu/fork"><img src="https://img.shields.io/github/forks/foldright/cffu?style=flat" alt="GitHub Forks"></a>
<a href="https://github.com/foldright/cffu/issues"><img src="https://img.shields.io/github/issues/foldright/cffu" alt="GitHub Issues"></a>
<a href="https://github.com/foldright/cffu/graphs/contributors"><img src="https://img.shields.io/github/contributors/foldright/cffu" alt="GitHub Contributors"></a>
<a href="https://github.com/foldright/cffu"><img src="https://img.shields.io/github/repo-size/foldright/cffu" alt="GitHub repo size"></a>
Expand Down Expand Up @@ -52,7 +52,7 @@
- [2.3 高效灵活的并发执行策略(`allOfFastFail`/`anyOfSuccess`](#23-%E9%AB%98%E6%95%88%E7%81%B5%E6%B4%BB%E7%9A%84%E5%B9%B6%E5%8F%91%E6%89%A7%E8%A1%8C%E7%AD%96%E7%95%A5alloffastfailanyofsuccess)
- [2.4 支持超时的`join`的方法](#24-%E6%94%AF%E6%8C%81%E8%B6%85%E6%97%B6%E7%9A%84join%E7%9A%84%E6%96%B9%E6%B3%95)
- [2.5 `Backport`支持`Java 8`](#25-backport%E6%94%AF%E6%8C%81java-8)
- [2.5 返回具体类型的`anyOf`方法](#25-%E8%BF%94%E5%9B%9E%E5%85%B7%E4%BD%93%E7%B1%BB%E5%9E%8B%E7%9A%84anyof%E6%96%B9%E6%B3%95)
- [2.6 返回具体类型的`anyOf`方法](#26-%E8%BF%94%E5%9B%9E%E5%85%B7%E4%BD%93%E7%B1%BB%E5%9E%8B%E7%9A%84anyof%E6%96%B9%E6%B3%95)
- [更多功能说明](#%E6%9B%B4%E5%A4%9A%E5%8A%9F%E8%83%BD%E8%AF%B4%E6%98%8E)
- [3. 如何从直接使用`CompletableFuture`类迁移到`Cffu`](#3-%E5%A6%82%E4%BD%95%E4%BB%8E%E7%9B%B4%E6%8E%A5%E4%BD%BF%E7%94%A8completablefuture%E7%B1%BB%E8%BF%81%E7%A7%BB%E5%88%B0cffu%E7%B1%BB)
- [🔌 API Docs](#-api-docs)
Expand Down Expand Up @@ -412,27 +412,27 @@ public class DefaultExecutorSettingForCffu {
### 2.3 高效灵活的并发执行策略(`allOfFastFail`/`anyOfSuccess`

- `CompletableFuture``allOf`方法会等待所有输入`CF`运行完成;即使有`CF`失败了也要等待后续`CF`运行完成,再返回一个失败`CF`
- 对于业务逻辑来说,这样失败的继续等待策略,减慢了业务响应性,会希望如果有输入`CF`失败了,而快速失败不再等待;
当所有的输入`CF`都成功时,才返回成功
- `CompletableFuture``allOf`方法会等待所有输入`CF`运行完成;即使有`CF`失败了也要等待后续`CF`运行完成,再返回一个失败的`CF`
- 对于业务逻辑来说,这样失败且继续等待策略,减慢了业务响应性;会希望如果有输入`CF`失败了,则快速失败不再做于事无补的等待
- `cffu`提供了相应的`cffuAllOfFastFail`/`allOfFastFail`方法
- `CompletableFuture``anyOf`方法返回首个完成的`CF`(不会等待后续没有完成`CF`,赛马模式);即使首个完成的`CF`是失败的,也会返回这个失败的`CF`
- 对于业务逻辑来说,会希望赛马模式返回首个成功的`CF`,而不是首个完成但失败的`CF`
当所有的输入`CF`都失败时,才返回失败
- `allOf`/`allOfFastFail`两者都是,只有当所有的输入`CF`都成功时,才返回成功结果
- `CompletableFuture``anyOf`方法返回首个完成的`CF`(不会等待后续没有完成的`CF`,赛马模式);即使首个完成的`CF`是失败的,也会返回这个失败的`CF`结果。
- 对于业务逻辑来说,会希望赛马模式返回首个成功的`CF`结果,而不是首个完成但失败的`CF`
- `cffu`提供了相应的`cffuAnyOfSuccess`/`anyOfSuccess`方法
- `anyOfSuccess`只有当所有的输入`CF`都失败时,才返回失败结果

> 📔 关于多个`CF`的并发执行策略,可以看看`Javascript`[`Promise Concurrency`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise#promise_concurrency);在`Javascript`中,`Promise`即对应`CompletableFuture`
> 📔 关于多个`CF`的并发执行策略,可以看看`JavaScript`规范[`Promise Concurrency`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise#promise_concurrency);在`JavaScript`中,`Promise`即对应`CompletableFuture`
>
> `Javascript Promise`提供了4个并发执行方法:
> `JavaScript Promise`提供了4个并发执行方法:
>
> - [`Promise.all()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/all):等待所有`Promise`运行完成,只要有一个失败就返回失败(对应`cffu``allOfFastFail`方法)
> - [`Promise.all()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/all):等待所有`Promise`运行成功,只要有一个失败就立即返回失败(对应`cffu``allOfFastFail`方法)
> - [`Promise.allSettled()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/allSettled):等待所有`Promise`运行完成,不管成功失败(对应`cffu``allOf`方法)
> - [`Promise.any()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/any):赛马模式,返回首个成功的`Promise`(对应`cffu``anyOfSuccess`方法)
> - [`Promise.race()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/race):赛马模式,返回首个完成的`Promise`(对应`cffu``anyOf`方法)
> - [`Promise.any()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/any):赛马模式,立即返回首个成功的`Promise`(对应`cffu``anyOfSuccess`方法)
> - [`Promise.race()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/race):赛马模式,立即返回首个完成的`Promise`(对应`cffu``anyOf`方法)
>
> PS:`Javascript Promise`的方法命名真考究真好 👍
> PS:`JavaScript Promise`的方法命名真考究~ 👍
>
> `cffu`新加2个方法后,`Javascript Promise`规范的并发方法一致对齐了~ 👏
> `cffu`新加2个方法后,对齐了`JavaScript Promise`规范的并发方法~ 👏
示例代码如下:

Expand Down Expand Up @@ -515,7 +515,7 @@ public class ConcurrencyStrategyDemo {

这些`backport`的方法是`CompletableFuture`的已有功能,不附代码示例。

### 2.5 返回具体类型的`anyOf`方法
### 2.6 返回具体类型的`anyOf`方法

`CompletableFuture.anyOf`方法返回类型是`Object`,丢失具体类型,不够类型安全,使用时需要转型也不方便。

Expand Down
6 changes: 4 additions & 2 deletions cffu-core/src/main/java/io/foldright/cffu/Cffu.java
Original file line number Diff line number Diff line change
Expand Up @@ -1695,8 +1695,8 @@ public Cffu<T> copy() {

/**
* Returns the default Executor used for async methods that do not specify an Executor.
* This class uses the {@code CffuFactory.defaultExecutor}
* config by {@link CffuFactoryBuilder#newCffuFactoryBuilder(Executor)}.
* Config from the {@link CffuFactory#defaultExecutor()},
* and can re-configured by {@link #resetCffuFactory(CffuFactory)}.
*
* @return the default executor
* @see CffuFactory#defaultExecutor()
Expand All @@ -1710,6 +1710,7 @@ public Executor defaultExecutor() {

/**
* Returns the {@link CffuFactory} of this Cffu.
* This can be re-configured by {@link #resetCffuFactory(CffuFactory)}.
*
* @return the CffuFactory
* @see #defaultExecutor()
Expand All @@ -1721,6 +1722,7 @@ public CffuFactory cffuFactory() {

/**
* Returns {@code forbidObtrudeMethods} or not.
* This can be re-configured by {@link #resetCffuFactory(CffuFactory)}.
*
* @see Cffu#obtrudeValue(Object)
* @see Cffu#obtrudeException(Throwable)
Expand Down
11 changes: 6 additions & 5 deletions cffu-core/src/main/java/io/foldright/cffu/CffuFactory.java
Original file line number Diff line number Diff line change
Expand Up @@ -586,7 +586,7 @@ public Executor delayedExecutor(long delay, TimeUnit unit, Executor executor) {
////////////////////////////////////////////////////////////////////////////////

/**
* Returns a new Cffu with the results of all the given Cffus,
* Returns a new Cffu with the results in the <strong>same order</strong> of all the given Cffus,
* the new Cffu is completed when all the given Cffus complete.
* Returns a new Cffu that is completed when all the given Cffus complete.
* If any of the given Cffus complete exceptionally, then the returned Cffu
Expand All @@ -609,7 +609,7 @@ public final <T> Cffu<List<T>> cffuAllOf(Cffu<T>... cfs) {
}

/**
* Returns a new Cffu with the results of all the given CompletableFutures,
* Returns a new Cffu with the results in the <strong>same order</strong> of all the given CompletableFutures,
* the new Cffu is completed when all the given CompletableFutures complete.
* If any of the given CompletableFutures complete exceptionally, then the returned Cffu
* also does so, with a CompletionException holding this exception as its cause.
Expand Down Expand Up @@ -642,7 +642,7 @@ public <T> Cffu<List<T>> cffuAllOf() {
}

/**
* Returns a new Cffu with the results of all the given Cffus,
* Returns a new Cffu with the results in the <strong>same order</strong> of all the given Cffus,
* the new Cffu success when all the given Cffus success.
* If any of the given Cffus complete exceptionally, then the returned Cffu
* also does so *without* waiting other incomplete given Cffus,
Expand All @@ -663,7 +663,7 @@ public final <T> Cffu<List<T>> cffuAllOfFastFail(Cffu<T>... cfs) {
}

/**
* Returns a new Cffu with the results of all the given CompletableFutures,
* Returns a new Cffu with the results in the <strong>same order</strong> of all the given CompletableFutures,
* the new Cffu success when all the given CompletableFutures success.
* If any of the given CompletableFutures complete exceptionally, then the returned Cffu
* also does so *without* waiting other incomplete given CompletableFutures,
Expand Down Expand Up @@ -1177,7 +1177,8 @@ public static <T> CompletableFuture<T>[] completableFutureListToArray(List<Compl
////////////////////////////////////////////////////////////////////////////////

/**
* Returns {@code defaultExecutor}.
* Returns the default Executor used for async methods that do not specify an Executor.
* Configured by {@link CffuFactoryBuilder#newCffuFactoryBuilder(Executor)}.
*
* @return the default executor
* @see Cffu#defaultExecutor()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,8 @@ public final class CompletableFutureUtils {
////////////////////////////////////////////////////////////////////////////////

/**
* Returns a new CompletableFuture with the results of all the given CompletableFutures,
* the new CompletableFuture is completed when all the given CompletableFutures complete.
* Returns a new CompletableFuture with the results in the <strong>same order</strong> of all the given
* CompletableFutures, the new CompletableFuture is completed when all the given CompletableFutures complete.
* If any of the given CompletableFutures complete exceptionally, then the returned CompletableFuture
* also does so, with a CompletionException holding this exception as its cause.
* If no CompletableFutures are provided, returns a CompletableFuture completed
Expand Down Expand Up @@ -104,8 +104,8 @@ public static CompletableFuture<Void> allOfFastFail(CompletableFuture<?>... cfs)
}

/**
* Returns a new CompletableFuture with the results of all the given CompletableFutures,
* the new CompletableFuture success when all the given CompletableFutures success.
* Returns a new CompletableFuture with the results in the <strong>same order</strong> of all the given
* CompletableFutures, the new CompletableFuture success when all the given CompletableFutures success.
* If any of the given CompletableFutures complete exceptionally, then the returned CompletableFuture
* also does so *without* waiting other incomplete given CompletableFutures,
* with a CompletionException holding this exception as its cause.
Expand Down Expand Up @@ -981,7 +981,8 @@ public static <T, U> CompletableFuture<U> newIncompleteFuture(CompletableFuture<
/**
* Returns the default Executor used for async methods that do not specify an Executor.
* This class uses the {@link ForkJoinPool#commonPool()} if it supports more than one parallel thread,
* or else an Executor using one thread per async task.
* or else an Executor using one thread per async task.<br>
* <b><i>CAUTION:</i></b>This executor may be not suitable for common biz use(io intensive).
*
* @return the executor
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ private const val ERROR_MSG_FOR_COLL = "no cffuFactory argument provided when th
private const val ERROR_MSG_FOR_ARRAY = "no cffuFactory argument provided when this array is empty"

/**
* Returns a new Cffu with the results of all the given Cffus,
* Returns a new Cffu with the results in the <strong>same order</strong> of all the given Cffus,
* the new Cffu is completed when all the given Cffus complete.
* If any of the given Cffus complete exceptionally, then the returned Cffu
* also does so, with a CompletionException holding this exception as its cause.
Expand All @@ -87,7 +87,7 @@ fun <T> Collection<Cffu<T>>.allOfCffu(cffuFactory: CffuFactory = ABSENT): Cffu<L
}

/**
* Returns a new Cffu with the results of all the given Cffus,
* Returns a new Cffu with the results in the <strong>same order</strong> of all the given Cffus,
* the new Cffu is completed when all the given Cffus complete.
* If any of the given Cffus complete exceptionally, then the returned Cffu
* also does so, with a CompletionException holding this exception as its cause.
Expand All @@ -110,7 +110,7 @@ fun <T> Array<Cffu<T>>.allOfCffu(cffuFactory: CffuFactory = ABSENT): Cffu<List<T
}

/**
* Returns a new Cffu with the results of all the given CompletableFutures,
* Returns a new Cffu with the results in the <strong>same order</strong> of all the given CompletableFutures,
* the new Cffu is completed when all the given CompletableFutures complete.
* If any of the given CompletableFutures complete exceptionally, then the returned Cffu
* also does so, with a CompletionException holding this exception as its cause.
Expand All @@ -128,7 +128,7 @@ fun <T> Collection<CompletableFuture<T>>.allOfCffu(cffuFactory: CffuFactory): Cf
cffuFactory.cffuAllOf(*this.toTypedArray())

/**
* Returns a new Cffu with the results of all the given CompletableFutures,
* Returns a new Cffu with the results in the <strong>same order</strong> of all the given CompletableFutures,
* the new Cffu is completed when all the given CompletableFutures complete.
* If any of the given CompletableFutures complete exceptionally, then the returned Cffu
* also does so, with a CompletionException holding this exception as its cause.
Expand Down Expand Up @@ -223,7 +223,7 @@ fun Array<out CompletableFuture<*>>.allOfCffuVoid(cffuFactory: CffuFactory): Cff
cffuFactory.allOf(*this)

/**
* Returns a new Cffu with the results of all the given Cffus,
* Returns a new Cffu with the results in the <strong>same order</strong> of all the given Cffus,
* the new Cffu success when all the given Cffus success.
* If any of the given Cffus complete exceptionally, then the returned Cffu
* also does so *without* waiting other incomplete given Cffus,
Expand All @@ -247,7 +247,7 @@ fun <T> Collection<Cffu<T>>.allOfFastFailCffu(cffuFactory: CffuFactory = ABSENT)
}

/**
* Returns a new Cffu with the results of all the given Cffus,
* Returns a new Cffu with the results in the <strong>same order</strong> of all the given Cffus,
* the new Cffu success when all the given Cffus success.
* If any of the given Cffus complete exceptionally, then the returned Cffu
* also does so *without* waiting other incomplete given Cffus,
Expand All @@ -271,7 +271,7 @@ fun <T> Array<Cffu<T>>.allOfFastFailCffu(cffuFactory: CffuFactory = ABSENT): Cff
}

/**
* Returns a new Cffu with the results of all the given CompletableFutures,
* Returns a new Cffu with the results in the <strong>same order</strong> of all the given CompletableFutures,
* the new Cffu success when all the given CompletableFutures success.
* If any of the given CompletableFutures complete exceptionally, then the returned Cffu
* also does so *without* waiting other incomplete given CompletableFutures,
Expand All @@ -290,7 +290,7 @@ fun <T> Collection<CompletableFuture<T>>.allOfFastFailCffu(cffuFactory: CffuFact
cffuFactory.cffuAllOfFastFail(*this.toTypedArray())

/**
* Returns a new Cffu with the results of all the given CompletableFutures,
* Returns a new Cffu with the results in the <strong>same order</strong> of all the given CompletableFutures,
* the new Cffu success when all the given CompletableFutures success.
* If any of the given CompletableFutures complete exceptionally, then the returned Cffu
* also does so *without* waiting other incomplete given CompletableFutures,
Expand Down
Loading

0 comments on commit b4f93ea

Please sign in to comment.