Skip to main content

lateinit and Nullable Properties in Kotlin

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

Introduction

lateinit and Nullable Properties is a fundamental concept every Kotlin developer should understand. Null safety is one of Kotlin’s signature features. It catches null-related bugs at compile time instead of crashing at runtime with a NullPointerException.

Lateinit is used for non-nullable var properties that are initialized later. 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

  • lateinit is used for non-nullable var properties that are initialized later.
  • It applies only to mutable (var) properties of reference types.
  • Use isInitialized to check whether a lateinit property has been assigned.

Syntax

lateinit var name: String

lateinit and Nullable Properties in Kotlin Example Program in Kotlin

class User {
    lateinit var username: String
}

fun main(args: Array<String>) {
    val user = User()
    user.username = "Thiyagaraaj"
    println("Username: ${user.username}")
    println("Initialized: ${user::username.isInitialized}")
}

Sample Output

Username: Thiyagaraaj
Initialized: true

When to use

Use nullable types when a value may legitimately be absent — optional fields, parsed input, or database lookups that can miss.

How it works

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

  2. val user = User() assigns or updates a value used later in the program.

  3. user.username = "Thiyagaraaj" assigns or updates a value used later in the program.

  4. The println("Username: ${user.username}") statement writes a line to the console — this produces part of the sample output below.

  5. The println("Initialized: ${user::username.isInitialized}") statement writes a line to the console — this produces part of the sample output below.

  6. Lateinit is used for non-nullable var properties that are initialized later.

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

  • Prefer non-nullable types by default; add ? only when null is a valid state.
  • Use safe call (?.) and Elvis (?:) instead of force unwrap (!!) unless you are certain.
  • Handle nullable collections and nested properties with ?. chains or let blocks.

Common Mistakes

  • Using !! everywhere instead of handling null safely — this reintroduces NPE risk.
  • Forgetting that platform types from Java are implicitly nullable.
  • Comparing nullable strings with == without considering both sides may be null.

Key Points

  • lateinit is used for non-nullable var properties that are initialized later.
  • It applies only to mutable (var) properties of reference types.
  • Use isInitialized to check whether a lateinit property has been assigned.
  • Test the example locally and verify the output matches the sample.
  • Experiment by changing input values to see how behaviour changes.

Notes

  • Semicolons at the end of statements are optional in Kotlin.

Frequently Asked Questions

What is lateinit and Nullable Properties in Kotlin?
Lateinit is used for non-nullable var properties that are initialized later.
When should I use lateinit and Nullable Properties?
Use nullable types when a value may legitimately be absent — optional fields, parsed input, or database lookups that can miss.
How is lateinit and Nullable Properties different from Java?
Use isInitialized to check whether a lateinit property has been assigned.
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