Exception Handling Best Practices in Kotlin
On this page (12sections)
Introduction
Exception Handling Best Practices is a fundamental concept every Kotlin developer should understand. Exceptions signal that something went wrong at runtime. Kotlin treats checked exceptions differently from Java, encouraging explicit error handling where it matters.
Catch specific exceptions instead of generic Exception when possible. 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
- Catch specific exceptions instead of generic Exception when possible.
- Do not use exceptions for normal control flow.
- Provide meaningful error messages to help debugging.
Syntax
catch (e: IOException) { ... }
Exception Handling Best Practices in Kotlin Example Program in Kotlin
fun readValue(text: String): Int? {
return try {
text.toInt()
} catch (e: NumberFormatException) {
println("Please enter a valid number")
null
}
}
fun main(args: Array<String>) {
println(readValue("25"))
println(readValue("XYZ"))
}
Sample Output
25
Please enter a valid number
null
When to use
Use try/catch when calling code that can fail — file access, network calls, parsing — and you need a controlled recovery path.
How it works
-
The program starts with a
mainfunction — the entry point that runs when you execute the file. -
The
println("Please enter a valid number")statement writes a line to the console — this produces part of the sample output below. -
The
println(readValue("25"))statement writes a line to the console — this produces part of the sample output below. -
The
println(readValue("XYZ"))statement writes a line to the console — this produces part of the sample output below. -
Catch specific exceptions instead of generic Exception when possible.
-
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: catch specific exceptions instead of generic Exception when possible.
- 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
- Catch specific exceptions instead of generic Exception when possible.
- Do not use exceptions for normal control flow.
- Provide meaningful error messages to help debugging.
- 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.