C# - Polymorphism

Polymorphism in C#

Introduction to Polymorphism

Polymorphism is one of the four pillars of Object-Oriented Programming (OOP), along with encapsulation, inheritance, and abstraction. The term polymorphism comes from the Greek words "poly" (many) and "morph" (form), meaning many forms.

In C#, polymorphism allows objects of different classes related by inheritance to be treated as objects of a common base class. It enables a single interface to represent different underlying data types or classes.

In simple terms, polymorphism lets methods do different things based on the object they are acting upon, even though they share the same method name or interface.

Why Polymorphism Matters?

  • Code Reusability: Write generalized code that can work with any derived class.
  • Extensibility: Easily extend your application by adding new derived classes without changing existing code.
  • Maintainability: Reduce code duplication by sharing common method signatures and behaviors.
  • Flexibility: Call overridden methods dynamically at runtime, allowing varied behavior.

Types of Polymorphism in C#

C# supports two primary types of polymorphism:

1. Compile-time Polymorphism (Static Polymorphism)

Also called method overloading or operator overloading, this polymorphism is resolved during compile time.

Method Overloading

Occurs when multiple methods have the same name but different parameters (number, types, or order).

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(2, 3));          // Output: 5
        Console.WriteLine(calc.Add(2.5, 3.5));      // Output: 6.0
        Console.WriteLine(calc.Add(1, 2, 3));       // Output: 6
    }
}

Operator Overloading

C# allows you to redefine or overload most built-in operators for your own classes or structs.

class Complex
{
    public int Real { get; set; }
    public int Imaginary { get; set; }

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

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

    public override string ToString()
    {
        return $"{Real} + {Imaginary}i";
    }
}

class Program
{
    static void Main()
    {
        Complex c1 = new Complex(1, 2);
        Complex c2 = new Complex(3, 4);
        Complex c3 = c1 + c2;
        Console.WriteLine(c3);  // Output: 4 + 6i
    }
}

2. Runtime Polymorphism (Dynamic Polymorphism)

This is achieved through method overriding and is resolved during runtime using virtual methods and inheritance.

Method Overriding

When a derived class provides a specific implementation of a method already defined in its base class.

class Animal
{
    public virtual void MakeSound()
    {
        Console.WriteLine("Animal sound");
    }
}

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

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

class Program
{
    static void Main()
    {
        Animal myAnimal = new Animal();
        Animal myDog = new Dog();
        Animal myCat = new Cat();

        myAnimal.MakeSound(); // Output: Animal sound
        myDog.MakeSound();    // Output: Bark
        myCat.MakeSound();    // Output: Meow
    }
}

Understanding Virtual, Override, and New Keywords

Virtual Keyword

Used in a base class to indicate that a method or property can be overridden in a derived class.

Override Keyword

Used in a derived class to provide a new implementation of a virtual method or property declared in the base class.

New Keyword

Used to hide a member inherited from a base class with a new implementation. It is different from overriding and does not provide polymorphic behavior.

class BaseClass
{
    public virtual void Display()
    {
        Console.WriteLine("Base Display");
    }
    public void Show()
    {
        Console.WriteLine("Base Show");
    }
}

class DerivedClass : BaseClass
{
    public override void Display()
    {
        Console.WriteLine("Derived Display");
    }

    public new void Show()
    {
        Console.WriteLine("Derived Show");
    }
}

class Program
{
    static void Main()
    {
        BaseClass obj1 = new DerivedClass();
        obj1.Display();  // Calls Derived Display (polymorphism)
        obj1.Show();     // Calls Base Show (no polymorphism)

        DerivedClass obj2 = new DerivedClass();
        obj2.Display();  // Derived Display
        obj2.Show();     // Derived Show
    }
}

Polymorphism with Abstract Classes and Interfaces

Polymorphism is often implemented using abstract classes and interfaces, which define methods that derived classes must implement.

Example with Abstract Class

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

class Circle : Shape
{
    public double Radius { get; set; }
    public Circle(double r) { Radius = r; }

    public override double GetArea()
    {
        return Math.PI * Radius * Radius;
    }
}

class Rectangle : Shape
{
    public double Width { get; set; }
    public double Height { get; set; }
    public Rectangle(double w, double h)
    {
        Width = w;
        Height = h;
    }

    public override double GetArea()
    {
        return Width * Height;
    }
}

class Program
{
    static void Main()
    {
        Shape shape1 = new Circle(5);
        Shape shape2 = new Rectangle(4, 6);

        Console.WriteLine($"Circle Area: {shape1.GetArea()}");       // Output: Circle Area: 78.53981633974483
        Console.WriteLine($"Rectangle Area: {shape2.GetArea()}");    // Output: Rectangle Area: 24
    }
}

Example with Interface

interface IVehicle
{
    void Start();
}

class Car : IVehicle
{
    public void Start()
    {
        Console.WriteLine("Car starting...");
    }
}

class Bike : IVehicle
{
    public void Start()
    {
        Console.WriteLine("Bike starting...");
    }
}

class Program
{
    static void Main()
    {
        IVehicle vehicle = new Car();
        vehicle.Start();   // Output: Car starting...

        vehicle = new Bike();
        vehicle.Start();   // Output: Bike starting...
    }
}

Advantages of Polymorphism

  • Flexibility: Enables methods to use objects of different types at different times.
  • Extensibility: Easily add new classes without modifying existing code.
  • Maintainability: Reduces coupling by interacting through interfaces or base classes.
  • Reusability: Generalizes code for different derived types.

Polymorphism and Design Patterns

Many design patterns in software development rely heavily on polymorphism, including:

  • Factory Pattern: Uses polymorphism to create objects from a common interface.
  • Strategy Pattern: Enables swapping algorithms or behaviors at runtime.
  • Template Method Pattern: Defines skeleton of an algorithm in a base class, with polymorphic steps.

Abstract classes can define abstract methods which must be overridden, enabling polymorphism by enforcing derived classes to implement specific behavior.

Polymorphism in C# empowers developers to write flexible, extensible, and maintainable code. By allowing objects to behave differently based on their actual types, polymorphism supports the design of robust systems that can grow and evolve without requiring significant rewrites.

Understanding both compile-time and runtime polymorphism, along with the use of virtual methods, overrides, interfaces, and abstract classes, is essential to mastering C# and object-oriented design.

Proper use of polymorphism simplifies code interaction, improves reusability, and facilitates implementation of advanced design patterns, making it a fundamental concept in professional software development.

logo

C#

Beginner 5 Hours

Polymorphism in C#

Introduction to Polymorphism

Polymorphism is one of the four pillars of Object-Oriented Programming (OOP), along with encapsulation, inheritance, and abstraction. The term polymorphism comes from the Greek words "poly" (many) and "morph" (form), meaning many forms.

In C#, polymorphism allows objects of different classes related by inheritance to be treated as objects of a common base class. It enables a single interface to represent different underlying data types or classes.

In simple terms, polymorphism lets methods do different things based on the object they are acting upon, even though they share the same method name or interface.

Why Polymorphism Matters?

  • Code Reusability: Write generalized code that can work with any derived class.
  • Extensibility: Easily extend your application by adding new derived classes without changing existing code.
  • Maintainability: Reduce code duplication by sharing common method signatures and behaviors.
  • Flexibility: Call overridden methods dynamically at runtime, allowing varied behavior.

Types of Polymorphism in C#

C# supports two primary types of polymorphism:

1. Compile-time Polymorphism (Static Polymorphism)

Also called method overloading or operator overloading, this polymorphism is resolved during compile time.

Method Overloading

Occurs when multiple methods have the same name but different parameters (number, types, or order).

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(2, 3)); // Output: 5 Console.WriteLine(calc.Add(2.5, 3.5)); // Output: 6.0 Console.WriteLine(calc.Add(1, 2, 3)); // Output: 6 } }

Operator Overloading

C# allows you to redefine or overload most built-in operators for your own classes or structs.

class Complex { public int Real { get; set; } public int Imaginary { get; set; } public Complex(int r, int i) { Real = r; Imaginary = i; } // Overload + operator public static Complex operator +(Complex c1, Complex c2) { return new Complex(c1.Real + c2.Real, c1.Imaginary + c2.Imaginary); } public override string ToString() { return $"{Real} + {Imaginary}i"; } } class Program { static void Main() { Complex c1 = new Complex(1, 2); Complex c2 = new Complex(3, 4); Complex c3 = c1 + c2; Console.WriteLine(c3); // Output: 4 + 6i } }

2. Runtime Polymorphism (Dynamic Polymorphism)

This is achieved through method overriding and is resolved during runtime using virtual methods and inheritance.

Method Overriding

When a derived class provides a specific implementation of a method already defined in its base class.

class Animal { public virtual void MakeSound() { Console.WriteLine("Animal sound"); } } class Dog : Animal { public override void MakeSound() { Console.WriteLine("Bark"); } } class Cat : Animal { public override void MakeSound() { Console.WriteLine("Meow"); } } class Program { static void Main() { Animal myAnimal = new Animal(); Animal myDog = new Dog(); Animal myCat = new Cat(); myAnimal.MakeSound(); // Output: Animal sound myDog.MakeSound(); // Output: Bark myCat.MakeSound(); // Output: Meow } }

Understanding Virtual, Override, and New Keywords

Virtual Keyword

Used in a base class to indicate that a method or property can be overridden in a derived class.

Override Keyword

Used in a derived class to provide a new implementation of a virtual method or property declared in the base class.

New Keyword

Used to hide a member inherited from a base class with a new implementation. It is different from overriding and does not provide polymorphic behavior.

class BaseClass { public virtual void Display() { Console.WriteLine("Base Display"); } public void Show() { Console.WriteLine("Base Show"); } } class DerivedClass : BaseClass { public override void Display() { Console.WriteLine("Derived Display"); } public new void Show() { Console.WriteLine("Derived Show"); } } class Program { static void Main() { BaseClass obj1 = new DerivedClass(); obj1.Display(); // Calls Derived Display (polymorphism) obj1.Show(); // Calls Base Show (no polymorphism) DerivedClass obj2 = new DerivedClass(); obj2.Display(); // Derived Display obj2.Show(); // Derived Show } }

Polymorphism with Abstract Classes and Interfaces

Polymorphism is often implemented using abstract classes and interfaces, which define methods that derived classes must implement.

Example with Abstract Class

abstract class Shape { public abstract double GetArea(); } class Circle : Shape { public double Radius { get; set; } public Circle(double r) { Radius = r; } public override double GetArea() { return Math.PI * Radius * Radius; } } class Rectangle : Shape { public double Width { get; set; } public double Height { get; set; } public Rectangle(double w, double h) { Width = w; Height = h; } public override double GetArea() { return Width * Height; } } class Program { static void Main() { Shape shape1 = new Circle(5); Shape shape2 = new Rectangle(4, 6); Console.WriteLine($"Circle Area: {shape1.GetArea()}"); // Output: Circle Area: 78.53981633974483 Console.WriteLine($"Rectangle Area: {shape2.GetArea()}"); // Output: Rectangle Area: 24 } }

Example with Interface

interface IVehicle { void Start(); } class Car : IVehicle { public void Start() { Console.WriteLine("Car starting..."); } } class Bike : IVehicle { public void Start() { Console.WriteLine("Bike starting..."); } } class Program { static void Main() { IVehicle vehicle = new Car(); vehicle.Start(); // Output: Car starting... vehicle = new Bike(); vehicle.Start(); // Output: Bike starting... } }

Advantages of Polymorphism

  • Flexibility: Enables methods to use objects of different types at different times.
  • Extensibility: Easily add new classes without modifying existing code.
  • Maintainability: Reduces coupling by interacting through interfaces or base classes.
  • Reusability: Generalizes code for different derived types.

Polymorphism and Design Patterns

Many design patterns in software development rely heavily on polymorphism, including:

  • Factory Pattern: Uses polymorphism to create objects from a common interface.
  • Strategy Pattern: Enables swapping algorithms or behaviors at runtime.
  • Template Method Pattern: Defines skeleton of an algorithm in a base class, with polymorphic steps.

Abstract classes can define abstract methods which must be overridden, enabling polymorphism by enforcing derived classes to implement specific behavior.

Polymorphism in C# empowers developers to write flexible, extensible, and maintainable code. By allowing objects to behave differently based on their actual types, polymorphism supports the design of robust systems that can grow and evolve without requiring significant rewrites.

Understanding both compile-time and runtime polymorphism, along with the use of virtual methods, overrides, interfaces, and abstract classes, is essential to mastering C# and object-oriented design.

Proper use of polymorphism simplifies code interaction, improves reusability, and facilitates implementation of advanced design patterns, making it a fundamental concept in professional software development.

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