133 |
|
* directly invoke its left task before returning. (This is an analog |
134 |
|
* of tail recursion removal.) Also, because the task returns upon |
135 |
|
* executing its left task (rather than falling through to invoke |
136 |
< |
* tryComplete) the pending count is set to one: |
136 |
> |
* {@code tryComplete}) the pending count is set to one: |
137 |
|
* |
138 |
|
* <pre> {@code |
139 |
|
* class ForEach<E> ... |
303 |
|
* distinguishes cases. Most often, when the caller is {@code this}, |
304 |
|
* no action is necessary. Otherwise the caller argument can be used |
305 |
|
* (usually via a cast) to supply a value (and/or links to other |
306 |
< |
* values) to be combined. Asuuming proper use of pending counts, the |
306 |
> |
* values) to be combined. Assuming proper use of pending counts, the |
307 |
|
* actions inside {@code onCompletion} occur (once) upon completion of |
308 |
|
* a task and its subtasks. No additional synchronization is required |
309 |
|
* within this method to ensure thread safety of accesses to fields of |