Skip to main content

Flow Basics in Kotlin

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

Introduction

Flow Basics is a fundamental concept every Kotlin developer should understand. Flow streams values over time, similar to RxJava observables but with structured concurrency and coroutine integration.

Flow emits multiple values asynchronously like a stream. 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

  • Flow emits multiple values asynchronously like a stream.
  • Created using flow { } builder.
  • Represents cold stream that starts on collection.

Syntax

fun numbers(): Flow<Int> = flow { emit(1) }

Flow Basics in Kotlin Example Program in Kotlin

import kotlinx.coroutines.*
import kotlinx.coroutines.flow.*

fun main(args: Array<String>) = runBlocking {
    flow {
        emit(1)
        emit(2)
        emit(3)
    }.collect { value ->
        print("$value ")
    }
}

Sample Output

1 2 3

When to use

Use Flow for streams of values over time — sensor readings, paginated API pages, or search-as-you-type results.

How it works

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

  2. Flow emits multiple values asynchronously like a stream.

  3. 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: flow emits multiple values asynchronously like a stream.
  • 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

  • Flow emits multiple values asynchronously like a stream.
  • Created using flow { } builder.
  • Represents cold stream that starts on collection.
  • 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 Flow Basics in Kotlin?
Flow emits multiple values asynchronously like a stream.
When should I use Flow Basics?
Use Flow for streams of values over time — sensor readings, paginated API pages, or search-as-you-type results.
How is Flow Basics different from Java?
Represents cold stream that starts on collection.
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