Skip to main content

Exception Handling in async in Kotlin

2 min read
Share:
On this page (12sections)

Introduction

Exception Handling in async is a fundamental concept every Kotlin developer should understand. async starts parallel work and await retrieves its result. Together they compose concurrent operations without manual thread management.

Exceptions in async are stored in Deferred until await. In this tutorial you will learn the syntax, walk through a complete example program, study the sample output, and review best practices so you can apply the concept confidently in your own projects.

Definition

  • Exceptions in async are stored in Deferred until await.
  • Use try-catch around await to handle failures.
  • SupervisorJob can isolate child failures.

Syntax

try { deferred.await() } catch (e: Exception) { }

Exception Handling in async in Kotlin Example Program in Kotlin

import kotlinx.coroutines.*

fun main(args: Array<String>) = runBlocking {
    val deferred = async {
        throw IllegalStateException("Failed")
    }
    try {
        deferred.await()
    } catch (e: Exception) {
        println("Error: ${e.message}")
    }
}

Sample Output

Error: Failed

When to use

Use async/await when you have independent tasks that can run in parallel and you need to combine their results.

How it works

  1. The program starts with a main function — the entry point that runs when you execute the file.

  2. val deferred = async { assigns or updates a value used later in the program.

  3. The println("Error: ${e.message}") statement writes a line to the console — this produces part of the sample output below.

  4. Exceptions in async are stored in Deferred until await.

  5. Run the program in IntelliJ IDEA, Android Studio, or with the Kotlin command-line compiler (kotlinc / kotlin). Compare your console output with the sample output shown below.

Best Practices

  • Understand the core idea: exceptions in async are stored in Deferred until await.
  • Prefer readable names and small functions so examples map directly to real projects.
  • Run and modify the example — change values and observe how the output changes.

Common Mistakes

  • Skipping the example and only reading the definition — hands-on practice cements the concept.
  • Copying syntax without understanding nullable vs non-nullable types or scope rules.
  • Ignoring compiler warnings that often point to safer alternatives.

Key Points

  • Exceptions in async are stored in Deferred until await.
  • Use try-catch around await to handle failures.
  • SupervisorJob can isolate child failures.
  • Test the example locally and verify the output matches the sample.
  • Experiment by changing input values to see how behaviour changes.

Notes

  • Add the kotlinx-coroutines-core dependency when running coroutine examples outside Android or IntelliJ.
  • Semicolons at the end of statements are optional in Kotlin.

Frequently Asked Questions

What is Exception Handling in async in Kotlin?
Exceptions in async are stored in Deferred until await.
When should I use Exception Handling in async?
Use async/await when you have independent tasks that can run in parallel and you need to combine their results.
How is Exception Handling in async different from Java?
SupervisorJob can isolate child failures.
How do I practice this topic?
Copy the example program into IntelliJ IDEA or Android Studio, run it, then modify values or add print statements to confirm your understanding.

Related Tutorials

Search tutorials