tailrec Functions in Kotlin
On this page (12sections)
Introduction
tailrec Functions is a fundamental concept every Kotlin developer should understand. Functions are first-class in Kotlin — parameters, return types, and concise syntax make APIs easy to read and reuse.
Tailrec marks a recursive function that calls itself as the last operation. 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
- tailrec marks a recursive function that calls itself as the last operation.
- The compiler optimizes tailrec functions into an efficient loop.
- Use tailrec instead of manual loops for clear recursive algorithms like factorial.
Syntax
tailrec fun factorial(n: Int, acc: Int = 1): Int
tailrec Functions in Kotlin Example Program in Kotlin
tailrec fun factorial(n: Int, acc: Int = 1): Int {
return if (n <= 1) acc else factorial(n - 1, acc * n)
}
fun main() {
println("5! = ${factorial(5)}")
}
Sample Output
5! = 120
When to use
Use default and named parameters to reduce overloads; use single-expression functions for small pure helpers.
How it works
-
The program starts with a
mainfunction — the entry point that runs when you execute the file. -
Tailrec marks a recursive function that calls itself as the last operation.
-
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: tailrec marks a recursive function that calls itself as the last operation.
- 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
- tailrec marks a recursive function that calls itself as the last operation.
- The compiler optimizes tailrec functions into an efficient loop.
- Use tailrec instead of manual loops for clear recursive algorithms like factorial.
- 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 tailrec Functions in Kotlin?
When should I use tailrec Functions?
How is tailrec Functions different from Java?
How do I practice this topic?
Related Tutorials
Local Functions in Kotlin
Learn Local Functions in Kotlin with clear explanation, syntax, example program, sample output, best practices, and FAQs.
Read tutorialInfix Functions in Kotlin
Learn Infix Functions in Kotlin with clear explanation, syntax, example program, sample output, best practices, and FAQs.
Read tutorial