Reflection Basics in Kotlin
On this page (12sections)
Introduction
Reflection Basics is a fundamental concept every Kotlin developer should understand. Reflection inspects types, properties, and functions at runtime — useful for serialization libraries, DI frameworks, and testing utilities.
Reflection inspects program structure at runtime. 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
- Reflection inspects program structure at runtime.
- KClass and KFunction provide class and function metadata.
- Reflection has runtime cost; use when necessary.
Syntax
obj::class.members
Reflection Basics in Kotlin Example Program in Kotlin
class User(val id: Int, val name: String)
fun main(args: Array<String>) {
val user = User(1, "Riya")
val properties = user::class.members.filterIsInstance<kotlin.reflect.KProperty<*>>()
properties.forEach { println("${it.name} = ${it.get(user)}") }
}
Sample Output
id = 1
name = Riya
When to use
Use reflection sparingly for frameworks and generic utilities; prefer compile-time type safety when possible.
How it works
-
The program starts with a
mainfunction — the entry point that runs when you execute the file. -
val user = User(1, "Riya")assigns or updates a value used later in the program. -
val properties = user::class.members.filterIsInstance<kotlin.reflect.KProperty<*>>()assigns or updates a value used later in the program. -
The
println("${it.name} = ${it.get(user)}")statement writes a line to the console — this produces part of the sample output below. -
Reflection inspects program structure at runtime.
-
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: reflection inspects program structure at runtime.
- 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
- Reflection inspects program structure at runtime.
- KClass and KFunction provide class and function metadata.
- Reflection has runtime cost; use when necessary.
- 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.