abstract class RecursiveTask[V] extends ForkJoinTask[V]
A recursive result-bearing ForkJoinTask.
For a classic example, here is a task computing Fibonacci numbers:
 
class Fibonacci extends RecursiveTask {
  final int n;
  Fibonacci(int n) { this.n = n;  
  Integer compute() {
    if (n <= 1)
       return n;
    Fibonacci f1 = new Fibonacci(n - 1);
    f1.fork();
    Fibonacci f2 = new Fibonacci(n - 2);
    return f2.compute() + f1.join();
  }
}}
However, besides being a dumb way to compute Fibonacci functions (there is a simple fast linear algorithm that you'd use in practice), this is likely to perform poorly because the smallest subtasks are too small to be worthwhile splitting up. Instead, as is the case for nearly all fork/join applications, you'd pick some minimum granularity size (for example 10 here) for which you always sequentially solve rather than subdividing.
- Source
- RecursiveTask.java
- Since
- 1.7 
- Alphabetic
- By Inheritance
- RecursiveTask
- ForkJoinTask
- Serializable
- Future
- AnyRef
- Any
- by any2stringadd
- by StringFormat
- by Ensuring
- by ArrowAssoc
- Hide All
- Show All
- Public
- All
Instance Constructors
-  new RecursiveTask()
Concrete Value Members
- 
      
      
      
        
      
    
      
        
        def
      
      
        cancel(mayInterruptIfRunning: Boolean): Boolean
      
      
      Attempts to cancel execution of this task. Attempts to cancel execution of this task. This attempt will fail if the task has already completed or could not be cancelled for some other reason. If successful, and this task has not started when cancelis called, execution of this task is suppressed. After this method returns successfully, unless there is an intervening call to#reinitialize, subsequent calls to#isCancelled,#isDone, andcancelwill returntrueand calls to#joinand related methods will result inCancellationException.This method may be overridden in subclasses, but if so, must still ensure that these properties hold. In particular, the cancelmethod itself must not throw exceptions.This method is designed to be invoked by other tasks. To terminate the current task, you can just return or throw an unchecked exception from its computation method, or invoke #completeExceptionally.- mayInterruptIfRunning
- this value has no effect in the default implementation because interrupts are not used to control cancellation. 
- returns
- trueif this task is now cancelled
 - Definition Classes
- ForkJoinTask → Future
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        compareAndSetForkJoinTaskTag(e: Short, tag: Short): Boolean
      
      
      Atomically conditionally sets the tag value for this task. Atomically conditionally sets the tag value for this task. Among other applications, tags can be used as visit markers in tasks operating on graphs, as in methods that check: if (task.compareAndSetForkJoinTaskTag((short)0, (short)1))before processing, otherwise exiting because the node has already been visited.- e
- the expected tag value 
- tag
- the new tag value 
- returns
- true if successful; i.e., the current value was equal to e and is now tag. 
 - Definition Classes
- ForkJoinTask
- Since
- 1.8 
 
- 
      
      
      
        
      
    
      
        
        def
      
      
        complete(value: V): Unit
      
      
      Completes this task, and if not already aborted or cancelled, returning the given value as the result of subsequent invocations of joinand related operations.Completes this task, and if not already aborted or cancelled, returning the given value as the result of subsequent invocations of joinand related operations. This method may be used to provide results for asynchronous tasks, or to provide alternative handling for tasks that would not otherwise complete normally. Its use in other situations is discouraged. This method is overridable, but overridden versions must invokesuperimplementation to maintain guarantees.- value
- the result value for this task 
 - Definition Classes
- ForkJoinTask
 
- 
      
      
      
        
      
    
      
        
        def
      
      
        completeExceptionally(ex: Throwable): Unit
      
      
      Completes this task abnormally, and if not already aborted or cancelled, causes it to throw the given exception upon joinand related operations.Completes this task abnormally, and if not already aborted or cancelled, causes it to throw the given exception upon joinand related operations. This method may be used to induce exceptions in asynchronous tasks, or to force completion of tasks that would not otherwise complete. Its use in other situations is discouraged. This method is overridable, but overridden versions must invokesuperimplementation to maintain guarantees.- ex
- the exception to throw. If this exception is not a - RuntimeExceptionor- Error, the actual exception thrown will be a- RuntimeExceptionwith cause- ex.
 - Definition Classes
- ForkJoinTask
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        fork(): ForkJoinTask[V]
      
      
      Arranges to asynchronously execute this task in the pool the current task is running in, if applicable, or using the ForkJoinPool#commonPool()if not#inForkJoinPool.Arranges to asynchronously execute this task in the pool the current task is running in, if applicable, or using the ForkJoinPool#commonPool()if not#inForkJoinPool. While it is not necessarily enforced, it is a usage error to fork a task more than once unless it has completed and been reinitialized. Subsequent modifications to the state of this task or any data it operates on are not necessarily consistently observable by any thread other than the one executing it unless preceded by a call to#joinor related methods, or a call to#isDonereturningtrue.- returns
- this, to simplify usage
 - Definition Classes
- ForkJoinTask
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        get(timeout: Long, unit: TimeUnit): V
      
      
      Waits if necessary for at most the given time for the computation to complete, and then retrieves its result, if available. Waits if necessary for at most the given time for the computation to complete, and then retrieves its result, if available. - timeout
- the maximum time to wait 
- unit
- the time unit of the timeout argument 
- returns
- the computed result 
 - Definition Classes
- ForkJoinTask → Future
- Exceptions thrown
- CancellationExceptionif the computation was cancelled- ExecutionExceptionif the computation threw an exception- InterruptedExceptionif the current thread is not a member of a ForkJoinPool and was interrupted while waiting- TimeoutExceptionif the wait timed out
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        get(): V
      
      
      Waits if necessary for the computation to complete, and then retrieves its result. Waits if necessary for the computation to complete, and then retrieves its result. - returns
- the computed result 
 - Definition Classes
- ForkJoinTask → Future
- Exceptions thrown
- CancellationExceptionif the computation was cancelled- ExecutionExceptionif the computation threw an exception- InterruptedExceptionif the current thread is not a member of a ForkJoinPool and was interrupted while waiting
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        getException(): Throwable
      
      
      Returns the exception thrown by the base computation, or a CancellationExceptionif cancelled, ornullif none or if the method has not yet completed.Returns the exception thrown by the base computation, or a CancellationExceptionif cancelled, ornullif none or if the method has not yet completed.- returns
- the exception, or - nullif none
 - Definition Classes
- ForkJoinTask
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        getForkJoinTaskTag(): Short
      
      
      Returns the tag for this task. 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        getRawResult(): V
      
      
      Returns the result that would be returned by #join, even if this task completed abnormally, ornullif this task is not known to have been completed.Returns the result that would be returned by #join, even if this task completed abnormally, ornullif this task is not known to have been completed. This method is designed to aid debugging, as well as to support extensions. Its use in any other context is discouraged.- returns
- the result, or - nullif not completed
 - Definition Classes
- RecursiveTask → ForkJoinTask
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        invoke(): V
      
      
      Commences performing this task, awaits its completion if necessary, and returns its result, or throws an (unchecked) RuntimeExceptionorErrorif the underlying computation did so.Commences performing this task, awaits its completion if necessary, and returns its result, or throws an (unchecked) RuntimeExceptionorErrorif the underlying computation did so.- returns
- the computed result 
 - Definition Classes
- ForkJoinTask
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        isCancelled(): Boolean
      
      
      - Definition Classes
- ForkJoinTask → Future
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        isCompletedAbnormally(): Boolean
      
      
      Returns trueif this task threw an exception or was cancelled.Returns trueif this task threw an exception or was cancelled.- returns
- trueif this task threw an exception or was cancelled
 - Definition Classes
- ForkJoinTask
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        isCompletedNormally(): Boolean
      
      
      Returns trueif this task completed without throwing an exception and was not cancelled.Returns trueif this task completed without throwing an exception and was not cancelled.- returns
- trueif this task completed without throwing an exception and was not cancelled
 - Definition Classes
- ForkJoinTask
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        isDone(): Boolean
      
      
      - Definition Classes
- ForkJoinTask → Future
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        join(): V
      
      
      Returns the result of the computation when it is done.Returns the result of the computation when it is done. This method differs from#get()in that abnormal completion results inRuntimeExceptionorError, notExecutionException, and that interrupts of the calling thread do not cause the method to abruptly return by throwingInterruptedException.- returns
- the computed result 
 - Definition Classes
- ForkJoinTask
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        quietlyComplete(): Unit
      
      
      Completes this task normally without setting a value. Completes this task normally without setting a value. The most recent value established by #setRawResult(ornullby default) will be returned as the result of subsequent invocations ofjoinand related operations.- Definition Classes
- ForkJoinTask
- Since
- 1.8 
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        quietlyInvoke(): Unit
      
      
      Commences performing this task and awaits its completion if necessary, without returning its result or throwing its exception. Commences performing this task and awaits its completion if necessary, without returning its result or throwing its exception. - Definition Classes
- ForkJoinTask
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        quietlyJoin(): Unit
      
      
      Joins this task, without returning its result or throwing its exception. Joins this task, without returning its result or throwing its exception. This method may be useful when processing collections of tasks when some have been cancelled or otherwise known to have aborted. - Definition Classes
- ForkJoinTask
 
- 
      
      
      
        
      
    
      
        
        def
      
      
        reinitialize(): Unit
      
      
      Resets the internal bookkeeping state of this task, allowing a subsequent fork.Resets the internal bookkeeping state of this task, allowing a subsequent fork. This method allows repeated reuse of this task, but only if reuse occurs when this task has either never been forked, or has been forked, then completed and all outstanding joins of this task have also completed. Effects under any other usage conditions are not guaranteed. This method may be useful when executing pre-constructed trees of subtasks in loops.Upon completion of this method, isDone()reportsfalse, andgetException()reportsnull. However, the value returned bygetRawResultis unaffected. To clear this value, you can invokesetRawResult(null).- Definition Classes
- ForkJoinTask
 
- 
      
      
      
        
      
    
      
        final 
        def
      
      
        setForkJoinTaskTag(tag: Short): Short
      
      
      Atomically sets the tag value for this task. Atomically sets the tag value for this task. - tag
- the tag value 
- returns
- the previous value of the tag 
 - Definition Classes
- ForkJoinTask
- Since
- 1.8 
 
- 
      
      
      
        
      
    
      
        
        def
      
      
        tryUnfork(): Boolean
      
      
      Tries to unschedule this task for execution. Tries to unschedule this task for execution. This method will typically (but is not guaranteed to) succeed if this task is the most recently forked task by the current thread, and has not commenced executing in another thread. This method may be useful when arranging alternative local processing of tasks that could have been, but were not, stolen. - returns
- trueif unforked
 - Definition Classes
- ForkJoinTask