Book Image

Learn Kotlin Programming - Second Edition

By : Stephen Samuel, Stefan Bocutiu
Book Image

Learn Kotlin Programming - Second Edition

By: Stephen Samuel, Stefan Bocutiu

Overview of this book

Kotlin is a general-purpose programming language used for developing cross-platform applications. Complete with a comprehensive introduction and projects covering the full set of Kotlin programming features, this book will take you through the fundamentals of Kotlin and get you up to speed in no time. Learn Kotlin Programming covers the installation, tools, and how to write basic programs in Kotlin. You'll learn how to implement object-oriented programming in Kotlin and easily reuse your program or parts of it. The book explains DSL construction, serialization, null safety aspects, and type parameterization to help you build robust apps. You'll learn how to destructure expressions and write your own. You'll then get to grips with building scalable apps by exploring advanced topics such as testing, concurrency, microservices, coroutines, and Kotlin DSL builders. Furthermore, you'll be introduced to the kotlinx.serialization framework, which is used to persist objects in JSON, Protobuf, and other formats. By the end of this book, you'll be well versed with all the new features in Kotlin and will be able to build robust applications skillfully.
Table of Contents (21 chapters)
Free Chapter
1
Section 1: Fundamental Concepts in Kotlin
5
Section 2: Practical Concepts in Kotlin
15
Section 3: Advanced Concepts in Kotlin

Async

The other main coroutine builder alongside launch is async , which creates a coroutine that returns a computed value. (Recall that launch was used for side effects.) The computed value is wrapped inside a class called Deferred that allows access to the eventual result through an await function that suspends the calling coroutine until the value is available. You can think of deferred as the coroutine equivalent of a regular Future.

A deferred coroutine is a subclass of Job, so all the functions on job apply to deferred as well.

Let's look at async in action:

fun main() {
runBlocking {
val deferred = async {
println("Computing value...")
delay(1000)
"result"
}
val result = deferred.await()
println("The result is $result")
}
}

Running this example, outputs the following:

Computing value...
The result is result
...