Variance in out in Kotlin
On this page (12sections)
Introduction
Variance in out is a fundamental concept every Kotlin developer should understand. Generics let you write type-safe containers and algorithms that work with many types while keeping compile-time checks.
Out makes type parameter covariant (producer). 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
- out makes type parameter covariant (producer).
- in makes type parameter contravariant (consumer).
- Variance controls subtype relationships for generics.
Syntax
interface Source<out T>
Variance in out in Kotlin Example Program in Kotlin
interface Producer<out T> {
fun produce(): T
}
class StringProducer : Producer<String> {
override fun produce() = "Kotlin"
}
fun main(args: Array<String>) {
val producer: Producer<Any> = StringProducer()
println(producer.produce())
}
Sample Output
Kotlin
When to use
Use generics when building reusable containers, parsers, or algorithms that must work with more than one type.
How it works
-
The program starts with a
mainfunction — the entry point that runs when you execute the file. -
override fun produce() = "Kotlin"assigns or updates a value used later in the program. -
val producer: Producer<Any> = StringProducer()assigns or updates a value used later in the program. -
The
println(producer.produce())statement writes a line to the console — this produces part of the sample output below. -
Out makes type parameter covariant (producer).
-
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: out makes type parameter covariant (producer).
- 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
- out makes type parameter covariant (producer).
- in makes type parameter contravariant (consumer).
- Variance controls subtype relationships for generics.
- 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 Variance in out in Kotlin?
When should I use Variance in out?
How is Variance in out different from Java?
How do I practice this topic?
Related Tutorials
Type Constraints in Kotlin
Learn Type Constraints in Kotlin with clear explanation, syntax, example program, sample output, best practices, and FAQs.
Read tutorialStar Projection in Kotlin
Learn Star Projection in Kotlin with clear explanation, syntax, example program, sample output, best practices, and FAQs.
Read tutorial