Skip to main content

Coroutine Scope in Kotlin

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

Introduction

Coroutine Scope is a fundamental concept every Kotlin developer should understand. Coroutines let you write asynchronous code that reads like synchronous code, without blocking threads or nesting callbacks.

CoroutineScope defines lifecycle of coroutines. 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

  • CoroutineScope defines lifecycle of coroutines.
  • Structured concurrency ensures child coroutines finish before scope closes.
  • coroutineScope builder waits for all child coroutines.

Syntax

coroutineScope { launch { } }

Coroutine Scope in Kotlin Example Program in Kotlin

import kotlinx.coroutines.*

fun main(args: Array<String>) = runBlocking {
    coroutineScope {
        launch { delay(50); println("Child 1") }
        launch { delay(30); println("Child 2") }
    }
    println("Scope completed")
}

Sample Output

Child 2
Child 1
Scope completed

When to use

Use coroutines for network requests, database queries, or any work that would block the main thread if done synchronously.

How it works

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

  2. The println("Child 1") statement writes a line to the console — this produces part of the sample output below.

  3. The println("Child 2") statement writes a line to the console — this produces part of the sample output below.

  4. The println("Scope completed") statement writes a line to the console — this produces part of the sample output below.

  5. CoroutineScope defines lifecycle of coroutines.

  6. 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

  • Never block the main thread — use suspend functions and appropriate dispatchers.
  • Scope coroutines with coroutineScope or supervisorScope for structured cancellation.
  • Use delay instead of Thread.sleep inside coroutines.

Common Mistakes

  • Launching coroutines without a scope — leaks work after the UI is destroyed.
  • Using GlobalScope in application code instead of a lifecycle-aware scope.
  • Calling blocking APIs directly on Dispatchers.Main.

Key Points

  • CoroutineScope defines lifecycle of coroutines.
  • Structured concurrency ensures child coroutines finish before scope closes.
  • coroutineScope builder waits for all child coroutines.
  • 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 Coroutine Scope in Kotlin?
CoroutineScope defines lifecycle of coroutines.
When should I use Coroutine Scope?
Use coroutines for network requests, database queries, or any work that would block the main thread if done synchronously.
How is Coroutine Scope different from Java?
CoroutineScope builder waits for all child coroutines.
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