lateinit and Nullable Properties in Kotlin
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
-
The program starts with a
mainfunction — the entry point that runs when you execute the file. -
val user = User()assigns or updates a value used later in the program. -
user.username = "Thiyagaraaj"assigns or updates a value used later in the program. -
The
println("Username: ${user.username}")statement writes a line to the console — this produces part of the sample output below. -
The
println("Initialized: ${user::username.isInitialized}")statement writes a line to the console — this produces part of the sample output below. -
Lateinit is used for non-nullable var properties that are initialized later.
-
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 orletblocks.
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?
When should I use lateinit and Nullable Properties?
How is lateinit and Nullable Properties different from Java?
How do I practice this topic?
Related Tutorials
also Operator for Null Handling in Kotlin
Learn also Operator for Null Handling in Kotlin with clear explanation, syntax, example program, sample output, best practices, and FAQs.
Read tutorialElvis Operator for Default Values in Kotlin
Learn Elvis Operator for Default Values in Kotlin with clear explanation, syntax, example program, sample output, best practices, and FAQs.
Read tutorial