Primary Constructor in Kotlin
On this page (12sections)
Introduction
Primary Constructor is a fundamental concept every Kotlin developer should understand. Classes bundle data and behaviour. Kotlin reduces boilerplate with concise constructors, properties, and sensible defaults compared to Java.
Primary constructor is part of the class header. 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
- Primary constructor is part of the class header.
- Constructor parameters can become properties using val or var.
- An init block runs during object initialization.
Syntax
class User(val id: Int)
Primary Constructor in Kotlin Example Program in Kotlin
class User(val id: Int, var active: Boolean) {
init {
println("User object created with id $id")
}
}
fun main(args: Array<String>) {
val user = User(101, true)
println("Active: ${user.active}")
}
Sample Output
User object created with id 101
Active: true
When to use
Use classes to model entities with state and behaviour — users, orders, view models, or service objects.
How it works
-
The program starts with a
mainfunction — the entry point that runs when you execute the file. -
The
println("User object created with id $id")statement writes a line to the console — this produces part of the sample output below. -
val user = User(101, true)assigns or updates a value used later in the program. -
The
println("Active: ${user.active}")statement writes a line to the console — this produces part of the sample output below. -
Primary constructor is part of the class header.
-
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
- Keep constructors short; move complex setup to init blocks or factory functions.
- Expose behaviour through methods rather than public mutable fields.
- Mark classes
final(default) unless inheritance is intentional.
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
- Primary constructor is part of the class header.
- Constructor parameters can become properties using val or var.
- An init block runs during object initialization.
- 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 Primary Constructor in Kotlin?
When should I use Primary Constructor?
How is Primary Constructor different from Java?
How do I practice this topic?
Related Tutorials
Class Constructors in Kotlin
Learn Class Constructors in Kotlin with clear explanation, syntax, example program, sample output, best practices, and FAQs.
Read tutorialSecondary Constructor in Kotlin
Learn Secondary Constructor in Kotlin with clear explanation, syntax, example program, sample output, best practices, and FAQs.
Read tutorial