public static class Job.DefaultImpls
A background job. Conceptually, a job is a cancellable thing with a simple life-cycle that culminates in its completion. Jobs can be arranged into parent-child hierarchies where cancellation or completion of parent immediately cancels all its children.
The most basic instances of interface Job are created with launch coroutine builder or with a
Job() factory function.  Other coroutine builders and primitives like
interface Deferred also implement interface Job interface.
A job has the following states:
| State                               | isActive | isCompleted | isCancelled |
| --------------------------------------- | ---------- | ------------- | ------------- |
| New (optional initial state)          | false    | false       | false       |
| Active (default initial state)        | true     | false       | false       |
| Completing (optional transient state) | true     | false       | false       |
| Cancelling (optional transient state) | false    | false       | true        |
| Cancelled (final state)               | false    | true        | true        |
| Completed (final state)               | false    | true        | false       |
Usually, a job is created in active state (it is created and started). However, coroutine builders
that provide an optional start parameter create a coroutine in new state when this parameter is set to
CoroutineStart.LAZY. Such a job can be made active by invoking Job.start or join.
A job can be cancelled at any time with cancel function that forces it to transition to
cancelling state immediately. Job that is not backed by a coroutine and does not have
Job.attachChild becomes cancelled on cancel immediately.
Otherwise, job becomes cancelled  when it finishes executing its code and
when all its children complete.
                                                        wait children
      +-----+       start      +--------+   complete   +-------------+  finish  +-----------+
      | New | ---------------> | Active | -----------> | Completing  | -------> | Completed |
      +-----+                  +--------+              +-------------+          +-----------+
         |                         |                         |
         | cancel                  | cancel                  | cancel
         V                         V                         |
    +-----------+   finish   +------------+                  |
    | Cancelled | <--------- | Cancelling | <----------------+
    |(completed)|            +------------+
    +-----------+
A job in the coroutineContext represents the coroutine itself. A job is active while the coroutine is working and job's cancellation aborts the coroutine when the coroutine is suspended on a cancellable suspension point by throwing CancellationException.
A job can have a parent job. A job with a parent is cancelled when its parent is cancelled or completes exceptionally.
Parent job waits for all its Job.attachChild to complete in completing or cancelling state.
Completing state is purely internal to the job. For an outside observer a completing job is still active,
while internally it is waiting for its children.
All functions on this interface and on all interfaces derived from it are thread-safe and can be safely invoked from concurrent coroutines without external synchronization.
| Modifier and Type | Method and Description | 
|---|---|
| static <R> R | fold(Job $this,
    R initial,
    kotlin.jvm.functions.Function2<? super R,? super kotlin.coroutines.experimental.CoroutineContext.Element,? extends R> operation) | 
| static <E extends Element> | get(Job $this,
   kotlin.coroutines.experimental.CoroutineContext.Key<E> key) | 
| static kotlin.coroutines.experimental.CoroutineContext | minusKey(Job $this,
        kotlin.coroutines.experimental.CoroutineContext.Key<?> key) | 
| static kotlin.coroutines.experimental.CoroutineContext | plus(Job $this,
    kotlin.coroutines.experimental.CoroutineContext context) | 
public static kotlin.coroutines.experimental.CoroutineContext plus(Job $this, kotlin.coroutines.experimental.CoroutineContext context)
public static <R> R fold(Job $this, R initial, kotlin.jvm.functions.Function2<? super R,? super kotlin.coroutines.experimental.CoroutineContext.Element,? extends R> operation)
public static <E extends Element> E get(Job $this, kotlin.coroutines.experimental.CoroutineContext.Key<E> key)
public static kotlin.coroutines.experimental.CoroutineContext minusKey(Job $this, kotlin.coroutines.experimental.CoroutineContext.Key<?> key)