Lesson 3
Polymorphism in Kotlin: Dynamic and Static Examples
Polymorphism in Kotlin: Dynamic and Static Examples

Greetings! In today's lesson, we'll unravel the concept of polymorphism in Kotlin's Object-Oriented Programming (OOP). Grasping polymorphism enables us to use a single entity (a method, class, or interface) to represent different types in various scenarios. Let's proceed.

Seeing Polymorphism in Action

Polymorphism, a pillar of OOP, allows one object to embody multiple forms. Visualize a button in software; depending on its type (for instance, a submit button or a radio button), the action resulting from pressing it varies. This dynamic encapsulates the spirit of polymorphism!

Kotlin supports various types of polymorphism. Run-time polymorphism, also known as dynamic polymorphism, occurs during runtime and leverages method overriding. Let's observe dynamic polymorphism in action within a simple application involving shapes. The base Shape class has an area method, which calculates the area for shapes. This method is uniquely implemented in the subclasses Rectangle and Circle.

Kotlin
1abstract class Shape { 2 abstract fun area(): Double 3} 4 5class Rectangle(private val length: Double, private val width: Double) : Shape() { 6 override fun area(): Double { 7 return length * width 8 } 9} 10 11class Circle(private val radius: Double) : Shape() { 12 override fun area(): Double { 13 return Math.PI * radius * radius 14 } 15} 16 17fun main() { 18 val rectangle: Shape = Rectangle(2.0, 3.0) 19 println(rectangle.area()) // Prints: 6.0 20 21 val circle: Shape = Circle(5.0) 22 println(circle.area()) // Prints: 78.5 23}

Here, polymorphism shines as the area() method takes on multiple forms while using the same Shape abstract class. It behaves differently depending on whether the object is a Rectangle or a Circle.

Method Overloading: Static Polymorphism

Another type of polymorphism that Kotlin supports is compile-time polymorphism, also known as static polymorphism, which operates during compile time and involves method overloading. Let's look at the example of static polymorphism:

Kotlin
1class MathOperations { 2 // Overloaded method for rectangle area 3 fun area(length: Double, width: Double): Double { 4 return length * width 5 } 6 7 // Overloaded method for circle area 8 fun area(radius: Double): Double { 9 return Math.PI * radius * radius 10 } 11} 12 13fun main() { 14 val mathOps = MathOperations() 15 println(mathOps.area(5.0, 2.0)) // Rectangle area 16 println(mathOps.area(3.0)) // Circle area 17}

In this example, polymorphism is demonstrated via method overloading. The area method has multiple forms, accepting different parameter lists to compute the area of either a rectangle or a circle based on the provided arguments. This is a clear example of static polymorphism, where the correct method is determined at compile time.

Lesson Summary

Great job! We've now learned about polymorphism, observed its implementation, and discovered its applications. Now, prepare for hands-on practice tasks. Apply what you've learned and excel in Kotlin programming. Happy coding!

Enjoy this lesson? Now it's time to practice with Cosmo!
Practice is how you turn knowledge into actual skills.