C# - Polymorphism

Polymorphism in C# 

Introduction to C# Polymorphism

C# Polymorphism is one of the four fundamental pillars of Object-Oriented Programming (OOP) in C#. Along with Encapsulation, Abstraction, and Inheritance, polymorphism plays a crucial role in designing scalable, maintainable, and flexible applications in the .NET Framework and modern .NET Core environments.

The word polymorphism is derived from two Greek words: β€œpoly” meaning many, and β€œmorph” meaning forms. In simple terms, polymorphism means β€œmany forms.” In C#, it allows methods, objects, and operators to behave differently based on the context in which they are used.

In real-world software development using C#, polymorphism enables developers to write reusable, clean, and loosely coupled code. It enhances flexibility in application architecture and allows different objects to respond to the same method call in different ways.

What is Polymorphism in C#?

Polymorphism in C# allows a single interface, method, or function name to represent multiple implementations. It enables one method to perform different tasks depending on the object that invokes it.

In C#, polymorphism is achieved in two major ways:

  • Compile-Time Polymorphism (Static Polymorphism)
  • Runtime Polymorphism (Dynamic Polymorphism)

Understanding both types is essential for mastering Object-Oriented Programming in C#.

Types of Polymorphism in C#

1. Compile-Time Polymorphism in C#

Compile-time polymorphism is also known as Static Polymorphism. It is achieved through:

  • Method Overloading
  • Operator Overloading

The method call is resolved at compile time. The compiler determines which method to invoke based on method signature.

Method Overloading in C#

Method overloading occurs when multiple methods have the same name but different parameters (type, number, or order).

Example: Method Overloading


using System;

class Calculator
{
    public int Add(int a, int b)
    {
        return a + b;
    }

    public double Add(double a, double b)
    {
        return a + b;
    }

    public int Add(int a, int b, int c)
    {
        return a + b + c;
    }
}

class Program
{
    static void Main()
    {
        Calculator calc = new Calculator();

        Console.WriteLine(calc.Add(10, 20));
        Console.WriteLine(calc.Add(10.5, 20.5));
        Console.WriteLine(calc.Add(5, 10, 15));
    }
}

In this example, the method Add behaves differently depending on parameters. This is a classic demonstration of compile-time polymorphism in C#.

Operator Overloading in C#

C# allows redefining the behavior of operators for user-defined types.


using System;

class Complex
{
    public int Real;
    public int Imaginary;

    public Complex(int r, int i)
    {
        Real = r;
        Imaginary = i;
    }

    public static Complex operator +(Complex c1, Complex c2)
    {
        return new Complex(c1.Real + c2.Real, c1.Imaginary + c2.Imaginary);
    }
}

This example shows how the + operator is overloaded for a custom class.

2. Runtime Polymorphism in C#

Runtime polymorphism is also known as Dynamic Polymorphism. It is achieved through:

  • Method Overriding
  • Virtual Methods
  • Abstract Methods
  • Interface Implementation

The method call is resolved at runtime using dynamic method dispatch.

Method Overriding in C#

Method overriding occurs when a derived class provides a specific implementation of a method that is already defined in the base class using the virtual keyword.

Rules for Method Overriding:

  • Base class method must be marked as virtual.
  • Derived class method must use override keyword.
  • Method signature must be the same.

Example: Runtime Polymorphism in C#


using System;

class Animal
{
    public virtual void Speak()
    {
        Console.WriteLine("Animal makes a sound");
    }
}

class Dog : Animal
{
    public override void Speak()
    {
        Console.WriteLine("Dog barks");
    }
}

class Cat : Animal
{
    public override void Speak()
    {
        Console.WriteLine("Cat meows");
    }
}

class Program
{
    static void Main()
    {
        Animal a1 = new Dog();
        Animal a2 = new Cat();

        a1.Speak();
        a2.Speak();
    }
}

Even though the reference type is Animal, the method executed depends on the object type at runtime. This is true runtime polymorphism in C#.

Virtual Methods in C#

A virtual method allows a derived class to override it. It supports runtime polymorphism.

Virtual methods provide flexibility while maintaining a default implementation.

Abstract Class and Polymorphism in C#

An abstract class cannot be instantiated and may contain abstract methods without implementation.


using System;

abstract class Shape
{
    public abstract double CalculateArea();
}

class Circle : Shape
{
    public double Radius;

    public Circle(double r)
    {
        Radius = r;
    }

    public override double CalculateArea()
    {
        return 3.14 * Radius * Radius;
    }
}

Abstract methods enforce derived classes to implement specific behavior, strengthening runtime polymorphism in C#.

Interface and Polymorphism in C#

Interfaces provide 100% abstraction and allow multiple inheritance in C#.


using System;

interface IPayment
{
    void ProcessPayment();
}

class CreditCard : IPayment
{
    public void ProcessPayment()
    {
        Console.WriteLine("Processing Credit Card Payment");
    }
}

class PayPal : IPayment
{
    public void ProcessPayment()
    {
        Console.WriteLine("Processing PayPal Payment");
    }
}

Here, different classes implement the same interface differently. This demonstrates runtime polymorphism using interfaces in C#.

Difference Between Compile-Time and Runtime Polymorphism

Feature Compile-Time Polymorphism Runtime Polymorphism
Resolution Time Compile Time Runtime
Achieved By Method Overloading Method Overriding
Keyword Used No special keyword virtual and override
Performance Faster Slightly slower due to dynamic binding

Real-World Example of Polymorphism in C#

Polymorphism is widely used in enterprise-level applications such as:

  • Payment gateway systems
  • Logging frameworks
  • Notification services
  • Dependency Injection in ASP.NET Core
  • Repository pattern implementations

For example, in ASP.NET Core applications, services are injected through interfaces, enabling runtime polymorphism.

Advantages of Polymorphism in C#

  • Improves code reusability
  • Enhances scalability
  • Supports loose coupling
  • Encourages clean architecture
  • Improves maintainability
  • Reduces code duplication

Polymorphism and SOLID Principles

Polymorphism directly supports:

  • Open/Closed Principle
  • Liskov Substitution Principle
  • Dependency Inversion Principle

Using runtime polymorphism ensures that new features can be added without modifying existing code.

C# Polymorphism is a powerful concept in Object-Oriented Programming that enables flexibility, scalability, and maintainability in software development. Understanding compile-time polymorphism (method overloading) and runtime polymorphism (method overriding, interfaces, abstract classes) is essential for mastering C# programming.

By implementing polymorphism effectively, developers can build enterprise-level applications using .NET Framework and .NET Core with clean architecture and SOLID design principles.

logo

C#

Beginner 5 Hours

Polymorphism in C# 

Introduction to C# Polymorphism

C# Polymorphism is one of the four fundamental pillars of Object-Oriented Programming (OOP) in C#. Along with Encapsulation, Abstraction, and Inheritance, polymorphism plays a crucial role in designing scalable, maintainable, and flexible applications in the .NET Framework and modern .NET Core environments.

The word polymorphism is derived from two Greek words: “poly” meaning many, and “morph” meaning forms. In simple terms, polymorphism means “many forms.” In C#, it allows methods, objects, and operators to behave differently based on the context in which they are used.

In real-world software development using C#, polymorphism enables developers to write reusable, clean, and loosely coupled code. It enhances flexibility in application architecture and allows different objects to respond to the same method call in different ways.

What is Polymorphism in C#?

Polymorphism in C# allows a single interface, method, or function name to represent multiple implementations. It enables one method to perform different tasks depending on the object that invokes it.

In C#, polymorphism is achieved in two major ways:

  • Compile-Time Polymorphism (Static Polymorphism)
  • Runtime Polymorphism (Dynamic Polymorphism)

Understanding both types is essential for mastering Object-Oriented Programming in C#.

Types of Polymorphism in C#

1. Compile-Time Polymorphism in C#

Compile-time polymorphism is also known as Static Polymorphism. It is achieved through:

  • Method Overloading
  • Operator Overloading

The method call is resolved at compile time. The compiler determines which method to invoke based on method signature.

Method Overloading in C#

Method overloading occurs when multiple methods have the same name but different parameters (type, number, or order).

Example: Method Overloading

using System; class Calculator { public int Add(int a, int b) { return a + b; } public double Add(double a, double b) { return a + b; } public int Add(int a, int b, int c) { return a + b + c; } } class Program { static void Main() { Calculator calc = new Calculator(); Console.WriteLine(calc.Add(10, 20)); Console.WriteLine(calc.Add(10.5, 20.5)); Console.WriteLine(calc.Add(5, 10, 15)); } }

In this example, the method Add behaves differently depending on parameters. This is a classic demonstration of compile-time polymorphism in C#.

Operator Overloading in C#

C# allows redefining the behavior of operators for user-defined types.

using System; class Complex { public int Real; public int Imaginary; public Complex(int r, int i) { Real = r; Imaginary = i; } public static Complex operator +(Complex c1, Complex c2) { return new Complex(c1.Real + c2.Real, c1.Imaginary + c2.Imaginary); } }

This example shows how the + operator is overloaded for a custom class.

2. Runtime Polymorphism in C#

Runtime polymorphism is also known as Dynamic Polymorphism. It is achieved through:

  • Method Overriding
  • Virtual Methods
  • Abstract Methods
  • Interface Implementation

The method call is resolved at runtime using dynamic method dispatch.

Method Overriding in C#

Method overriding occurs when a derived class provides a specific implementation of a method that is already defined in the base class using the virtual keyword.

Rules for Method Overriding:

  • Base class method must be marked as virtual.
  • Derived class method must use override keyword.
  • Method signature must be the same.

Example: Runtime Polymorphism in C#

using System; class Animal { public virtual void Speak() { Console.WriteLine("Animal makes a sound"); } } class Dog : Animal { public override void Speak() { Console.WriteLine("Dog barks"); } } class Cat : Animal { public override void Speak() { Console.WriteLine("Cat meows"); } } class Program { static void Main() { Animal a1 = new Dog(); Animal a2 = new Cat(); a1.Speak(); a2.Speak(); } }

Even though the reference type is Animal, the method executed depends on the object type at runtime. This is true runtime polymorphism in C#.

Virtual Methods in C#

A virtual method allows a derived class to override it. It supports runtime polymorphism.

Virtual methods provide flexibility while maintaining a default implementation.

Abstract Class and Polymorphism in C#

An abstract class cannot be instantiated and may contain abstract methods without implementation.

using System; abstract class Shape { public abstract double CalculateArea(); } class Circle : Shape { public double Radius; public Circle(double r) { Radius = r; } public override double CalculateArea() { return 3.14 * Radius * Radius; } }

Abstract methods enforce derived classes to implement specific behavior, strengthening runtime polymorphism in C#.

Interface and Polymorphism in C#

Interfaces provide 100% abstraction and allow multiple inheritance in C#.

using System; interface IPayment { void ProcessPayment(); } class CreditCard : IPayment { public void ProcessPayment() { Console.WriteLine("Processing Credit Card Payment"); } } class PayPal : IPayment { public void ProcessPayment() { Console.WriteLine("Processing PayPal Payment"); } }

Here, different classes implement the same interface differently. This demonstrates runtime polymorphism using interfaces in C#.

Difference Between Compile-Time and Runtime Polymorphism

Feature Compile-Time Polymorphism Runtime Polymorphism
Resolution Time Compile Time Runtime
Achieved By Method Overloading Method Overriding
Keyword Used No special keyword virtual and override
Performance Faster Slightly slower due to dynamic binding

Real-World Example of Polymorphism in C#

Polymorphism is widely used in enterprise-level applications such as:

  • Payment gateway systems
  • Logging frameworks
  • Notification services
  • Dependency Injection in ASP.NET Core
  • Repository pattern implementations

For example, in ASP.NET Core applications, services are injected through interfaces, enabling runtime polymorphism.

Advantages of Polymorphism in C#

  • Improves code reusability
  • Enhances scalability
  • Supports loose coupling
  • Encourages clean architecture
  • Improves maintainability
  • Reduces code duplication

Polymorphism and SOLID Principles

Polymorphism directly supports:

  • Open/Closed Principle
  • Liskov Substitution Principle
  • Dependency Inversion Principle

Using runtime polymorphism ensures that new features can be added without modifying existing code.

C# Polymorphism is a powerful concept in Object-Oriented Programming that enables flexibility, scalability, and maintainability in software development. Understanding compile-time polymorphism (method overloading) and runtime polymorphism (method overriding, interfaces, abstract classes) is essential for mastering C# programming.

By implementing polymorphism effectively, developers can build enterprise-level applications using .NET Framework and .NET Core with clean architecture and SOLID design principles.

Related Tutorials

Frequently Asked Questions for C#

C# is much easier to learn than C++. C# is a simpler, high-level-of-abstraction language, while C++ is a low-level language with a higher learning curve.

C# outshines Python when it comes to runtime performance. As a compiled language, C# code is converted to machine code, which can be executed more efficiently by the processor. This results in faster execution times and better performance, especially in resource-intensive tasks.

Python and JavaScript programmers also earn high salaries, ranking #3 and #4 in compensation. 
C# is the highest-paid programming language but has less demand than Python, JavaScript, and Java.

No. Microsoft has invested substantially in ensuring that C# is the dominant language today, spending two billion dollars on marketing and attempting to convince developers to embrace this new platform, which is also based on the.NET foundation.

C# is primarily used on the Windows .NET framework, although it can be applied to an open source platform. This highly versatile programming language is an object-oriented programming language (OOP) and comparably new to the game, yet a reliable crowd pleaser.


You can’t be able to become Master of C# in 3 months since it has many concepts to learn and implement. NOTE: no one can become master in particular programming language. Everyday they introducing new concepts we need to get practice on it which practically somewhat tough.

C-Sharp is one of the most widely used languages for creating system backend.It's because of its incredible features, such as Windows server automation. Apart from that, it's fantastic because it runs codes quite quickly. It can also be used to create CLI applications and game creation.

Easy to learn and use: C# is simpler than Java due to its use of fewer keywords and usually shorter lines of code. Hence, it is easier to learn to code in C# compared to Java. Flexible Data Types: C# provides more flexibility in defining data types than Java.

Four steps of code compilation in C# include : 
  • Source code compilation in managed code.
  • Newly created code is clubbed with assembly code.
  • The Common Language Runtime (CLR) is loaded.
  • Assembly execution is done through CLR.

The C# language is also easy to learn because by learning a small subset of the language you can immediately start to write useful code. More advanced features can be learnt as you become more proficient, but you are not forced to learn them to get up and running. C# is very good at encapsulating complexity.


The decision to opt for C# or Node. js largely hinges on the specific requirements of your project. If you're developing a CPU-intensive, enterprise-level application where stability and comprehensive tooling are crucial, C# might be your best bet.


Among other languages, C# is gaining huge popularity for developing web-based applications. Its core concepts help build an interactive environment and provide functionalities that the dynamic web platform requires. Most aspiring full-stack developers choose this versatile language.

The C# programming language was designed by Anders Hejlsberg from Microsoft in 2000 and was later approved as an international standard by Ecma (ECMA-334) in 2002 and ISO/IEC (ISO/IEC 23270 and 20619) in 2003. Microsoft introduced C# along with .NET Framework and Visual Studio, both of which were closed-source. 

C# outshines Python when it comes to runtime performance. As a compiled language, C# code is converted to machine code, which can be executed more efficiently by the processor. This results in faster execution times and better performance, especially in resource-intensive tasks.

Yes, C# is used by many large organizations, start-ups and beginners alike. It takes some of the useful features of C and adds syntax to save time and effort. Although C# is based on C, you can learn it without any knowledge of C β€” in fact, this course is perfect for those with no coding experience at all!

C# is a very mature language that evolved significantly over the years.
The C# language is one of the top 5 most popular programming languages and .NET is the most loved software development framework in the world.
TIOBE Index predicts C# as 2023 'Language of the Year' close to overtake Java in popularity.

Generally, the C# language is not limited to the Windows operating system. In a sense, however, it is limited to Microsoft software. C# language "belongs" to Microsoft, it is developed by Microsoft and it is Microsoft that provides the runtime environment required for the operation of programs written in C#.

C# (pronounced "C sharp") is called so because the "#" symbol is often referred to as "sharp." The name was chosen by Microsoft when they developed the language. It's a play on words related to musical notation where "C#" represents the musical note C sharp.

Dennis MacAlistair Ritchie (September 9, 1941 – c. October 12, 2011) was an American computer scientist. He created the C programming language and, with long-time colleague Ken Thompson, the Unix operating system and B language.

C# is part of .NET, a free and open source development platform for building apps that run on Windows, macOS, Linux, iOS, and Android. There's an active community answering questions, producing samples, writing tutorials, authoring books, and more.


line

Copyrights © 2024 letsupdateskills All rights reserved