Interface StructuredTaskScope.Subtask<T>
- Type Parameters:
T- the result type
- All Superinterfaces:
Supplier<T>
- Enclosing interface:
StructuredTaskScopePREVIEW<T,R>
Subtask is a preview API of the Java platform.
StructuredTaskScope.fork(Callable)PREVIEW or StructuredTaskScope.fork(Runnable)PREVIEW.
Code that forks subtasks can use the get() method after joiningPREVIEW to obtain the result of a subtask that completed successfully. It
can use the exception() method to obtain the exception thrown by a subtask
that failed.
- Since:
- 21
-
Nested Class Summary
Nested ClassesModifier and TypeInterfaceDescriptionstatic enumPreview.Represents the state of a subtask. -
Method Summary
-
Method Details
-
state
Returns the subtask state.- Returns:
- the subtask state
-
get
T get()Returns the result of this subtask if it completed successfully. If the subtask was forked withfork(Callable)PREVIEW then the result from thecallmethod is returned. If the subtask was forked withfork(Runnable)PREVIEW thennullis returned.Code executing in the scope owner thread can use this method to get the result of a successful subtask only after it has joinedPREVIEW.
Code executing in the
JoineronCompletePREVIEW method should test that the subtask state isSUCCESSPREVIEW before using this method to get the result. -
exception
Throwable exception()Returns the exception or error thrown by this subtask if it failed. If the subtask was forked withfork(Callable)PREVIEW then the exception or error thrown by thecallmethod is returned. If the subtask was forked withfork(Runnable)PREVIEW then the exception or error thrown by therunmethod is returned.Code executing in the scope owner thread can use this method to get the exception thrown by a failed subtask only after it has joinedPREVIEW.
Code executing in a
JoineronCompletePREVIEW method should test that the subtask state isFAILEDPREVIEW before using this method to get the exception.- Returns:
- the exception or error thrown by this subtask if it failed
- Throws:
IllegalStateException- if the subtask has not completed, completed with a result, or the current thread is the scope owner invoking this method before joiningPREVIEW- See Also:
-
Subtaskwhen preview features are enabled.