Skip to content

Commit

Permalink
Update task.md
Browse files Browse the repository at this point in the history
language checked
  • Loading branch information
stephen-hero authored Dec 11, 2023
1 parent 44ec4cf commit 7e1c049
Showing 1 changed file with 22 additions and 22 deletions.
44 changes: 22 additions & 22 deletions Coroutines/Coroutines/task.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,14 @@ block -> suspend
thread -> coroutine
```

> Coroutines are often called lightweight threads because you can run code on coroutines, similar to how you run code on
> threads. The operations that were blocking before (and had to be avoided) can now suspend the coroutine instead.
> Coroutines are often called lightweight threads due to the similarity in how code is run on both.
> Operations that previously blocked — and therefore had to be avoidedcan now instead suspend the coroutine.

### Starting a new coroutine

If you look at how `loadContributorsSuspend()` is used in [src/contributors/Contributors.kt](course://Coroutines/Coroutines/src/contributors/Contributors.kt), you can see that it's
called inside `launch`. `launch` is a library function that takes a lambda as an argument:
called within `launch`. `launch` is a library function that takes a lambda as an argument:

```kotlin
launch {
Expand All @@ -22,30 +22,30 @@ launch {
}
```

Here `launch` starts a new computation that is responsible for loading the data and showing the results. The computation
Here, `launch` starts a new computation responsible for both loading the data and showing the results. The computation
is suspendable – when performing network requests, it is suspended and releases the underlying thread.
When the network request returns the result, the computation is resumed.
When the network request returns a result, the computation resumes.

Such a suspendable computation is called a _coroutine_. So, in this case, `launch` _starts a new coroutine_ responsible
Such a suspendable computation is called a _coroutine_. Thus, in this case, `launch` _starts a new coroutine_ responsible
for loading data and showing the results.

Coroutines run on top of threads and can be suspended. When a coroutine is suspended, the
corresponding computation is paused, removed from the thread, and stored in memory. Meanwhile, the thread is free to be
occupied by other tasks:
Coroutines run over threads and can be suspended. When a coroutine is suspended, the
corresponding computation is paused, removed from the thread, and stored in memory. Meanwhile, the thread becomes free to
manage other tasks:

![Suspending coroutines](images/suspension-process.gif)

When the computation is ready to be continued, it is returned to a thread (not necessarily the same one).
When a computation is ready to be continued, it is returned to a thread (though, not necessarily the same one).

In the `loadContributorsSuspend()` example, each "contributors" request now waits for the result using the suspension
mechanism. First, the new request is sent. Then, while waiting for the response, the whole "load contributors" coroutine
that was started by the `launch` function is suspended.
In the `loadContributorsSuspend()` example, each "contributors" request now waits for the result by utilizing the suspension
mechanism. First, a new request is sent. Then, while waiting for a response, the entire "load contributors" coroutine
started by the `launch` function becomes suspended.

The coroutine resumes only after the corresponding response is received:
The coroutine resumes once the corresponding response is received:

![Suspending request](images/suspend-requests.png)

While the response is waiting to be received, the thread is free to be occupied by other tasks. The UI stays responsive,
While awaiting the response, the thread is free to undertake other tasks, keeping the UI responsive
despite all the requests taking place on the main UI thread:

1. Run the program using the _SUSPEND_ option. The log confirms that all of the requests are sent to the main UI thread:
Expand All @@ -58,20 +58,20 @@ despite all the requests taking place on the main UI thread:
11252 [AWT-EventQueue-0 @coroutine#1] INFO Contributors - kotlin-coroutines-workshop: loaded 1 contributors
```
2. The log can show you which coroutine the corresponding code is running on. For the configuration invoked by clicking `Run` button this is already set up. To enable it in your own configurations, open **Run | Edit configurations**
2. The log can show you which coroutine is running the corresponding code. For configuration invoked by clicking the `Run` button, this is already set up. To enable this in your own configurations, open **Run | Edit configurations**
and add the `-Dkotlinx.coroutines.debug` VM option:
![Edit run configuration](images/run-configuration.png) &shortcut:ChooseRunConfiguration;
The coroutine name will be attached to the thread name while `main()` is run with this option. You can also
modify the template for running all of the Kotlin files and enable this option by default.
The coroutine name will be attached to the thread name while `main()` is running with this option. You may also
modify the template for running all Kotlin files and enable this option by default.
Now all of the code runs on one coroutine, the "load contributors" coroutine mentioned above, denoted as `@coroutine#1`.
While waiting for the result, you shouldn't reuse the thread for sending other requests because the code is
written sequentially. The new request is sent only when the previous result is received.
Now all code runs within a single coroutine, the "load contributors" coroutine mentioned above, denoted as `@coroutine#1`.
While waiting for the result, you shouldn't reuse the thread for sending other requests, as the code is
written sequentially. A new request is sent only once the previous result has been received.
Suspending functions treat the thread fairly and don't block it for "waiting". However, this doesn't yet bring any concurrency
into the picture.
For a more detailed description, you can look at [this article](https://kotlinlang.org/docs/coroutines-and-channels.html#coroutines)
For a more detailed description, you can refer to [this article](https://kotlinlang.org/docs/coroutines-and-channels.html#coroutines).

0 comments on commit 7e1c049

Please sign in to comment.