Bird
Raised Fist0
C Sharp (C#)programming~3 mins

When to use abstract vs concrete in C Sharp (C#) - When to Use Which

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
The Big Idea

Ever felt stuck rewriting the same code over and over? Abstract vs concrete classes can free you from that pain!

The Scenario

Imagine you are building a car factory by hand. You have to create every single car model from scratch, even though many cars share common parts like wheels and engines. You write the same code again and again for these shared parts.

The Problem

This manual way is slow and confusing. You might forget to update a shared part in all car models, causing errors. It's hard to keep track of what is common and what is unique for each car.

The Solution

Using abstract and concrete classes helps you organize your code. Abstract classes let you define common parts once, like a blueprint, without making a full car. Concrete classes build on that blueprint to create actual car models. This saves time and reduces mistakes.

Before vs After
Before
class Car {
  public void StartEngine() { /* engine start code */ }
  public void Drive() { /* drive code */ }
}
class SportsCar : Car {
  public void TurboBoost() { /* turbo code */ }
}
After
abstract class Car {
  public abstract void StartEngine();
  public void Drive() { /* drive code */ }
}
class SportsCar : Car {
  public override void StartEngine() { /* engine start code */ }
  public void TurboBoost() { /* turbo code */ }
}
What It Enables

This approach lets you build flexible, reusable code that is easy to maintain and extend as your project grows.

Real Life Example

Think of a video game where you have a base character class with common actions like move and jump (abstract), and specific characters like wizard or warrior (concrete) that add unique skills.

Key Takeaways

Abstract classes define common blueprints without full details.

Concrete classes build actual objects using those blueprints.

Using both helps organize code, avoid repetition, and reduce errors.

Practice

(1/5)
1. Which statement best describes when to use an abstract class in C#?
easy
A. When you want to define a common plan without providing full implementation.
B. When you want to create a fully working class that can be instantiated.
C. When you want to prevent inheritance altogether.
D. When you want to create a class with only static methods.

Solution

  1. Step 1: Understand abstract class purpose

    An abstract class defines methods or properties that must be implemented by subclasses but does not provide full implementation itself.
  2. Step 2: Compare with concrete class

    Concrete classes provide full working code and can be instantiated, unlike abstract classes.
  3. Final Answer:

    When you want to define a common plan without providing full implementation. -> Option A
  4. Quick Check:

    Abstract class = common plan without full code [OK]
Hint: Abstract = plan only, Concrete = full working code [OK]
Common Mistakes:
  • Confusing abstract with concrete classes
  • Thinking abstract classes can be instantiated
  • Believing abstract classes provide full method bodies
2. Which of the following is the correct way to declare an abstract class in C#?
easy
A. class abstract Vehicle { }
B. public abstract class Vehicle { }
C. abstract public Vehicle { }
D. public class abstract Vehicle { }

Solution

  1. Step 1: Recall C# syntax for abstract classes

    The correct syntax places the keyword abstract before class and then the class name.
  2. Step 2: Check each option

    public abstract class Vehicle { } uses public abstract class Vehicle { }, which is correct. Other options have incorrect keyword order or missing keywords.
  3. Final Answer:

    public abstract class Vehicle { } -> Option B
  4. Quick Check:

    abstract class syntax = 'public abstract class' [OK]
Hint: Use 'abstract' before 'class' keyword [OK]
Common Mistakes:
  • Placing 'abstract' after 'class'
  • Omitting 'class' keyword
  • Incorrect keyword order
3. What will be the output of this C# code?
abstract class Animal {
    public abstract void Speak();
}

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

class Program {
    static void Main() {
        Animal a = new Dog();
        a.Speak();
    }
}
medium
A. Runtime error because Speak is abstract
B. Compile-time error because Animal is abstract
C. Woof
D. No output

Solution

  1. Step 1: Understand abstract method implementation

    The abstract method Speak in Animal is overridden in Dog with a concrete implementation that prints "Woof".
  2. Step 2: Analyze runtime behavior

    Creating an Animal reference to a Dog object and calling Speak() calls the overridden method, printing "Woof".
  3. Final Answer:

    Woof -> Option C
  4. Quick Check:

    Abstract method overridden = prints 'Woof' [OK]
Hint: Abstract method must be overridden to run [OK]
Common Mistakes:
  • Thinking abstract class cannot be referenced
  • Expecting compile or runtime error
  • Assuming abstract methods have bodies
4. Identify the error in this code snippet:
abstract class Shape {
    public abstract double Area();
}

class Circle : Shape {
    public double Area() {
        return 3.14 * 5 * 5;
    }
}
medium
A. Circle must declare Area() as override
B. Shape cannot have abstract methods
C. Circle cannot inherit from Shape
D. Area method should return int, not double

Solution

  1. Step 1: Check abstract method override rules

    When a class inherits an abstract method, it must override it using the override keyword.
  2. Step 2: Identify missing override keyword

    The Circle class defines Area() but misses override, causing a compile error.
  3. Final Answer:

    Circle must declare Area() as override -> Option A
  4. Quick Check:

    Override keyword required for abstract methods [OK]
Hint: Override abstract methods with 'override' keyword [OK]
Common Mistakes:
  • Omitting override keyword
  • Thinking abstract methods can be ignored
  • Confusing return types
5. You want to design a system where all vehicles must have a method StartEngine(), but the way engines start differs by vehicle type. Which approach is best in C#?
hard
A. Create a static class Vehicle with static StartEngine() method.
B. Create a concrete class Vehicle with a fully implemented StartEngine() method for all vehicles.
C. Use an interface with a concrete StartEngine() method and inherit it in all vehicle classes.
D. Create an abstract class Vehicle with abstract method StartEngine(), then implement it in subclasses.

Solution

  1. Step 1: Analyze requirement for different implementations

    Since StartEngine() differs by vehicle type, it should be declared abstract to force subclasses to provide their own version.
  2. Step 2: Choose correct class design

    An abstract class Vehicle with an abstract StartEngine() method fits best, allowing subclasses to implement specific behavior.
  3. Final Answer:

    Create an abstract class Vehicle with abstract method StartEngine(), then implement it in subclasses. -> Option D
  4. Quick Check:

    Abstract class for common plan, concrete for specifics [OK]
Hint: Abstract method for varying behavior, concrete class for details [OK]
Common Mistakes:
  • Using concrete class with one method for all vehicles
  • Trying to put method body in interface (not allowed)
  • Using static class which can't be inherited