withContext Dispatcher in Kotlin
On this page (12sections)
Introduction
withContext Dispatcher is a fundamental concept every Kotlin developer should understand. Dispatchers decide which thread pool runs coroutine code — Main for UI, IO for blocking work, and Default for CPU-bound tasks.
WithContext switches coroutine to another dispatcher and returns result. 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
- withContext switches coroutine to another dispatcher and returns result.
- Original context is restored after block completes.
- Useful for moving work off UI thread and back.
Syntax
withContext(Dispatchers.IO) { ... }
withContext Dispatcher in Kotlin Example Program in Kotlin
import kotlinx.coroutines.*
fun main(args: Array<String>) = runBlocking {
val data = withContext(Dispatchers.Default) {
"Processed data"
}
println(data)
}
Sample Output
Processed data
When to use
Switch dispatchers when moving between UI updates (Main) and blocking or CPU-heavy work (IO / Default).
How it works
-
The program starts with a
mainfunction — the entry point that runs when you execute the file. -
val data = withContext(Dispatchers.Default) {assigns or updates a value used later in the program. -
The
println(data)statement writes a line to the console — this produces part of the sample output below. -
WithContext switches coroutine to another dispatcher and returns result.
-
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: withContext switches coroutine to another dispatcher and returns result.
- 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
- withContext switches coroutine to another dispatcher and returns result.
- Original context is restored after block completes.
- Useful for moving work off UI thread and back.
- 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-coredependency when running coroutine examples outside Android or IntelliJ. - Semicolons at the end of statements are optional in Kotlin.
Frequently Asked Questions
What is withContext Dispatcher in Kotlin?
When should I use withContext Dispatcher?
How is withContext Dispatcher different from Java?
How do I practice this topic?
Related Tutorials
Dispatcher Default in Kotlin
Learn Dispatcher Default in Kotlin with clear explanation, syntax, example program, sample output, best practices, and FAQs.
Read tutorialCustom Dispatcher in Kotlin
Learn Custom Dispatcher in Kotlin with clear explanation, syntax, example program, sample output, best practices, and FAQs.
Read tutorial