Abstraction vs Interface

Abstraction

Abstraction is a concept that focuses on hiding the implementation details and showing only the necessary features of an object. In C#, abstraction can be achieved using abstract classes and methods.

Key Characteristics of Abstraction:

  1. Abstract Class: A class that cannot be instantiated on its own and may contain abstract methods (without implementation) and non-abstract methods (with implementation).

  2. Abstract Methods: Methods that are declared without any implementation and must be implemented by derived classes.

  3. Partial Implementation: An abstract class can provide some implementation while leaving other methods abstract for subclasses to implement.

  4. Access Modifiers: Abstract classes can have access modifiers (public, protected, etc.) to control the visibility of their members.

Example of Abstraction in C#:

public abstract class Animal
{
    public abstract void MakeSound(); // Abstract method

    public void Sleep()
    {
        Console.WriteLine("Sleeping...");
    }
}

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

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

class Program
{
    static void Main()
    {
        Animal myDog = new Dog();
        Animal myCat = new Cat();
        
        myDog.MakeSound(); // Output: Bark
        myCat.MakeSound(); // Output: Meow
        
        myDog.Sleep(); // Output: Sleeping...
        myCat.Sleep(); // Output: Sleeping...
    }
}

Interface

Interface is a programming structure that defines a contract. It specifies a set of methods and properties that a class must implement but does not provide any implementation.

Key Characteristics of Interface:

  1. No Implementation: Interfaces cannot contain any implementation. All methods and properties are implicitly abstract.

  2. Multiple Inheritance: A class can implement multiple interfaces, providing a way to achieve multiple inheritance.

  3. No Access Modifiers: All members of an interface are implicitly public.

  4. Flexibility: Interfaces provide more flexibility in designing loosely coupled systems.

Example of Interface in C#:

public interface IAnimal
{
    void MakeSound();
    void Sleep();
}

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

    public void Sleep()
    {
        Console.WriteLine("Sleeping...");
    }
}

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

    public void Sleep()
    {
        Console.WriteLine("Sleeping...");
    }
}

class Program
{
    static void Main()
    {
        IAnimal myDog = new Dog();
        IAnimal myCat = new Cat();
        
        myDog.MakeSound(); // Output: Bark
        myCat.MakeSound(); // Output: Meow
        
        myDog.Sleep(); // Output: Sleeping...
        myCat.Sleep(); // Output: Sleeping...
    }
}

Differences between Abstraction and Interface:

Feature
Abstract Class
Interface

Implementation

Can contain both abstract and concrete methods

Cannot contain any implementation

Multiple Inheritance

Not supported (a class can inherit only one abstract class)

Supported (a class can implement multiple interfaces)

Access Modifiers

Can have access modifiers for methods and properties

All members are implicitly public

Constructors

Can have constructors

Cannot have constructors

Fields

Can contain fields

Cannot contain fields

Use Case

When a base class is needed with some common implementation

When only a contract is needed

Similarities:

  1. Cannot Instantiate: Both cannot be instantiated directly.

  2. Contract Definition: Both can define a set of methods that must be implemented by derived classes or implementing classes.

  3. Polymorphism: Both can be used to achieve polymorphism, allowing objects to be treated as instances of their base type or interface.

When to Use Which:

  • Abstract Class: Use when you have a base class that should provide some common implementation and behavior that can be shared across multiple derived classes.

  • Interface: Use when you need to define a contract that multiple classes can implement, ensuring they adhere to a specific set of methods without dictating how those methods should be implemented.

In summary, abstract classes and interfaces are both used to define contracts and achieve polymorphism, but they have different capabilities and are suited for different scenarios. Abstract classes are better when you need to share common code among related classes, whereas interfaces are better for defining a contract that can be implemented by any class, regardless of where it sits in the class hierarchy.

Last updated