Skip to main content

C# : Mastering Method Overloading and Method Overriding



In the world of object-oriented programming, two essential concepts, method overloading and method overriding, play a crucial role in creating flexible and maintainable code.

In this blog post, we'll explore these concepts in C#, providing real-world examples and code snippets to illustrate their usage.

Method Overloading

Method overloading allows a class to have multiple methods with the same name but different parameters. It provides a way to create more readable and intuitive APIs by offering multiple ways to interact with a class or object.

Real-World Example: A Calculator Class

Imagine you're building a Calculator class. With method overloading, you can create various versions of the Add method to handle different types of inputs.
public class Calculator
{
    // Method Overloading
    public int Add(int a, int b)
    {
        return a + b;
    }
    public double Add(double a, double b)
    {
        return a + b;
    }
 
    public string Add(string a, string b)
    {
        return $"{a} {b}";
    }
}
 
class Program
{
    static void Main()
    {
        Calculator myCalculator = new Calculator();
 
        int sumInt = myCalculator.Add(5, 10);
        double sumDouble = myCalculator.Add(3.5, 7.2);
        string concatenatedStrings = myCalculator.Add("Hello", "World");
 
        Console.WriteLine($"Sum of integers: {sumInt}");
        Console.WriteLine($"Sum of doubles: {sumDouble}");
        Console.WriteLine($"Concatenated strings: {concatenatedStrings}");
    }
}
 

In this example, the Add method is overloaded to handle integer addition, double addition, and string concatenation. Method overloading simplifies the usage of the Calculator class by providing a variety of input options.

Method Overriding

Method overriding comes into play when dealing with inheritance. It allows a derived class to provide a specific implementation for a method that is already defined in its base class. This enables polymorphism, where objects of the derived class can be treated as objects of the base class.
Real-World Example: Shape Hierarchy

Consider a scenario where you have a base class Shape with a method CalculateArea. Various derived classes, such as Circle and Rectangle, can override this method to provide their specific implementations.
public class Shape
{
    public virtual double CalculateArea()
    {
        return 0; // Default implementation for unknown shapes
    }
}
 
public class Circle : Shape
{
    public double Radius { get; set; }
 
    public override double CalculateArea()
    {
        return Math.PI * Math.Pow(Radius, 2);
    }
}
 
public class Rectangle : Shape
{
    public double Length { get; set; }
    public double Width { get; set; }
 
    public override double CalculateArea()
    {
        return Length * Width;
    }
}
 
class Program
{
    static void Main()
    {
        Shape circle = new Circle { Radius = 5 };
        Shape rectangle = new Rectangle { Length = 4, Width = 6 };
 
        Console.WriteLine($"Circle Area: {circle.CalculateArea()}");
        Console.WriteLine($"Rectangle Area: {rectangle.CalculateArea()}");
    }
}
 

Here, the Circle and Rectangle classes override the CalculateArea method, providing specific implementations for calculating the area of a circle and rectangle. The polymorphic behaviour allows treating instances of derived classes as instances of the base class, enhancing code flexibility.

Conclusion

Method overloading and method overriding are powerful tools in C# that enhance the flexibility and maintainability of code.

Method overloading allows for the creation of more intuitive and versatile APIs, while method overriding, in the context of inheritance, enables polymorphic behaviour, allowing derived classes to provide specific implementations.

However, it's crucial to strike a balance. Overusing method overloading can lead to ambiguity, and overusing method overriding can result in complex hierarchies. When applying these concepts, consider the design principles of simplicity, clarity, and maintainability to ensure that your code remains robust and understandable.

By mastering method overloading and method overriding, C# developers can create expressive and adaptable code, providing a solid foundation for building scalable and maintainable software systems.

Happy coding!

Comments

Popular posts from this blog

C# : How can we access private method outside class

Introduction In object-oriented programming, encapsulation is a fundamental principle that restricts direct access to the internal implementation details of a class. Private methods, being part of this internal implementation, are designed to be accessible only within the confines of the class they belong to. However, there might be scenarios where you need to access a private method from outside the class. In this blog post, we'll explore several techniques to achieve this in C#. 1. Reflection: A Powerful Yet Delicate Approach Reflection is a mechanism in C# that allows inspecting and interacting with metadata about types, fields, properties, and methods. While it provides a way to access private methods, it should be used cautiously due to its potential impact on maintainability and performance. using System ; using System . Reflection ; public class MyClass { private void PrivateMethod ( ) { Console . WriteLine ( "This is a private method."...

20+ LINQ Concepts with .Net Code

LINQ   (Language Integrated Query) is one of the most powerful features in .NET, providing a unified syntax to query collections, databases, XML, and other data sources. Below are 20+ important LINQ concepts, their explanations, and code snippets to help you understand their usage. 1.  Where  (Filtering) The  Where()  method is used to filter a collection based on a given condition. var numbers = new List < int > { 1 , 2 , 3 , 4 , 5 , 6 } ; var evenNumbers = numbers . Where ( n => n % 2 == 0 ) . ToList ( ) ; // Output: [2, 4, 6] C# Copy 2.  Select  (Projection) The  Select()  method projects each element of a sequence into a new form, allowing transformation of data. var employees = new List < Employee > { /* ... */ } ; var employeeNames = employees . Select ( e => e . Name ) . ToList ( ) ; // Output: List of employee names C# Copy 3.  OrderBy  (Sorting in Ascending Order) The  Or...

C# : Understanding Types of Classes

In C#, classes serve as the building blocks of object-oriented programming, providing a blueprint for creating objects. Understanding the types of classes and their applications is crucial for designing robust and maintainable software. In this blog, we’ll delve into various types of classes in C#, accompanied by real-world scenarios and code snippets for a practical understanding. 1. Regular (Instance) Classes Definition: Regular classes are the most common type and are used to create instances or objects. They can contain fields, properties, methods, and other members. Example Scenario: A Person class representing individual persons with properties like Name and Age. public class Person { public string Name { get ; set ; } public int Age { get ; set ; } } 2. Static Classes Definition: A static class cannot be instantiated and can only contain static members (methods, properties, fields). It’s often used for utility functions. Example Scenario: A MathUtility cla...