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

Why Interface as contract mental model in C Sharp (C#)? - Purpose & Use Cases

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

What if you could guarantee everyone on your team knows exactly what to do, every time?

The Scenario

Imagine you and your friends agree to build a treehouse together. But no one writes down who will bring the hammer, who will cut the wood, or who will paint. Everyone just hopes others will do their part.

The Problem

Without clear agreements, tasks get missed, confusion grows, and the treehouse project slows down or fails. People guess what others will do, leading to mistakes and frustration.

The Solution

An interface acts like a clear contract. It tells everyone exactly what tasks must be done and how. This way, each friend knows their role, and the project moves smoothly without surprises.

Before vs After
Before
class TreehouseBuilder {
  public void Build() {
    // No clear rules, anyone can do anything
  }
}
After
interface IBuilder {
  void Build();
}
class TreehouseBuilder : IBuilder {
  public void Build() {
    // Clear contract: must implement Build
  }
}
What It Enables

It enables teams to work together confidently, knowing everyone follows the same clear rules.

Real Life Example

In a software app, different parts like payment or user login follow interfaces so developers can build or update them independently without breaking the whole system.

Key Takeaways

Interfaces define clear roles and expectations.

They prevent confusion and mistakes in teamwork.

They make code easier to manage and extend.

Practice

(1/5)
1.

What does an interface in C# represent?

easy
A. A contract that defines methods a class must implement
B. A class that contains method implementations
C. A variable type that stores data
D. A method that runs automatically

Solution

  1. Step 1: Understand the role of an interface

    An interface defines a set of method signatures without implementations.
  2. Step 2: Compare with classes

    Classes implement interfaces by providing method bodies, fulfilling the contract.
  3. Final Answer:

    A contract that defines methods a class must implement -> Option A
  4. Quick Check:

    Interface = contract for methods [OK]
Hint: Interfaces define method rules, not code bodies [OK]
Common Mistakes:
  • Thinking interfaces contain method code
  • Confusing interfaces with classes
  • Believing interfaces store data
2.

Which of the following is the correct way to declare an interface in C#?

?
easy
A. interface IAnimal { void Speak(); }
B. class IAnimal { void Speak(); }
C. interface IAnimal() { void Speak(); }
D. interface IAnimal { void Speak() {} }

Solution

  1. Step 1: Check interface declaration syntax

    Interfaces use the keyword 'interface' followed by the name and method signatures without bodies.
  2. Step 2: Identify correct method signature

    Method declarations in interfaces do not have bodies, so no curly braces after method.
  3. Final Answer:

    interface IAnimal { void Speak(); } -> Option A
  4. Quick Check:

    Interface syntax = keyword + method signatures [OK]
Hint: Interfaces have method signatures only, no bodies [OK]
Common Mistakes:
  • Adding parentheses after interface name
  • Using class keyword instead of interface
  • Providing method bodies inside interface
3.

What will be the output of the following code?

interface IWorker { void Work(); }
class Employee : IWorker {
  public void Work() { Console.WriteLine("Employee working"); }
}
class Robot : IWorker {
  public void Work() { Console.WriteLine("Robot working"); }
}
class Program {
  static void Main() {
    IWorker w = new Robot();
    w.Work();
  }
}
medium
A. No output
B. Employee working
C. Compilation error
D. Robot working

Solution

  1. Step 1: Identify the object type assigned to interface variable

    The variable 'w' is of type IWorker but assigned a new Robot instance.
  2. Step 2: Determine which Work() method runs

    Calling w.Work() runs Robot's Work method, printing "Robot working".
  3. Final Answer:

    Robot working -> Option D
  4. Quick Check:

    Interface variable calls actual object's method [OK]
Hint: Interface calls method of assigned object's class [OK]
Common Mistakes:
  • Assuming interface variable calls Employee method
  • Expecting compilation error due to interface
  • Thinking no output will print
4.

Identify the error in this code snippet:

interface IShape {
  double Area();
}
class Circle : IShape {
  public double Area() {
    return 3.14 * radius * radius;
  }
}
medium
A. Interface method cannot return double
B. Missing radius field or property in Circle class
C. Circle class should not implement IShape
D. Area method should be void

Solution

  1. Step 1: Check Circle class members

    The method Area uses 'radius' but no radius variable or property is declared in Circle.
  2. Step 2: Understand interface method return type

    Interface method returning double is valid; no error there.
  3. Final Answer:

    Missing radius field or property in Circle class -> Option B
  4. Quick Check:

    Undefined variable 'radius' causes error [OK]
Hint: Check all variables used are declared [OK]
Common Mistakes:
  • Thinking interface methods can't return values
  • Believing class can't implement interface
  • Assuming method return type must be void
5.

You want to create a system where different devices can Start() and Stop() but each device does it differently. How should you use interfaces to design this?

hard
A. Create a base class Device with Start and Stop methods and inherit it
B. Write Start and Stop methods directly in each device class without interface
C. Define an interface IDevice with Start and Stop methods, then implement it in each device class
D. Use abstract classes only, no interfaces

Solution

  1. Step 1: Understand interface purpose

    Interfaces define a contract for methods without implementation, perfect for different device behaviors.
  2. Step 2: Apply interface to devices

    Define IDevice with Start and Stop, then each device class implements these methods with its own details.
  3. Final Answer:

    Define an interface IDevice with Start and Stop methods, then implement it in each device class -> Option C
  4. Quick Check:

    Interface = shared method rules, different implementations [OK]
Hint: Use interfaces for shared method names, different code [OK]
Common Mistakes:
  • Using base class limits flexibility
  • Skipping interface loses contract benefits
  • Confusing abstract classes with interfaces