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

Default interface methods in C Sharp (C#) - Time & Space Complexity

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
Time Complexity: Default interface methods
O(n)
Understanding Time Complexity

When using default interface methods in C#, it's important to understand how the program's running time changes as input grows.

We want to see how calling these methods affects the total work done by the program.

Scenario Under Consideration

Analyze the time complexity of the following code snippet.


interface IPrinter
{
    void Print();
    void PrintMultiple(int times)
    {
        for (int i = 0; i < times; i++)
            Print();
    }
}

class ConsolePrinter : IPrinter
{
    public void Print() => Console.WriteLine("Hello");
}

// Usage
IPrinter printer = new ConsolePrinter();
printer.PrintMultiple(5);
    

This code defines an interface with a default method that calls another method multiple times. The class implements the interface and the default method is used to print a message repeatedly.

Identify Repeating Operations

Identify the loops, recursion, array traversals that repeat.

  • Primary operation: The for-loop inside the default method PrintMultiple that calls Print repeatedly.
  • How many times: The loop runs times times, which depends on the input parameter.
How Execution Grows With Input

Explain the growth pattern intuitively.

Input Size (times)Approx. Operations (Print calls)
1010
100100
10001000

Pattern observation: The number of print calls grows directly with the input number times. If you double times, the work doubles.

Final Time Complexity

Time Complexity: O(n)

This means the time to run PrintMultiple grows linearly with the number of times you want to print.

Common Mistake

[X] Wrong: "Default interface methods run instantly and don't add to execution time."

[OK] Correct: Even though the method is defined in the interface, it still runs its code each time it's called, so the loop inside causes repeated work proportional to the input.

Interview Connect

Understanding how default interface methods behave helps you reason about code performance and design choices, a useful skill in real projects and interviews.

Self-Check

"What if the default method called another default method inside the interface that also loops? How would the time complexity change?"

Practice

(1/5)
1. What is the main purpose of default interface methods in C#?
easy
A. Allow interfaces to have method bodies with default behavior
B. Force all implementing classes to override every method
C. Prevent interfaces from having any methods
D. Make interfaces behave like abstract classes

Solution

  1. Step 1: Understand interface limitations before default methods

    Interfaces could only declare methods without bodies, forcing all implementations to define them.
  2. Step 2: Recognize the role of default interface methods

    Default interface methods allow interfaces to provide a method body, so implementing classes can use or override it.
  3. Final Answer:

    Allow interfaces to have method bodies with default behavior -> Option A
  4. Quick Check:

    Default interface methods = method bodies in interfaces [OK]
Hint: Default interface methods add bodies to interfaces [OK]
Common Mistakes:
  • Thinking interfaces cannot have any method bodies
  • Confusing default methods with abstract methods
  • Believing all methods must be overridden
2. Which of the following is the correct syntax to declare a default interface method in C#?
easy
A. abstract void Show() { Console.WriteLine("Hello"); }
B. void Show();
C. default void Show() { Console.WriteLine("Hello"); }
D. void Show() => Console.WriteLine("Hello");

Solution

  1. Step 1: Recall default method syntax in interfaces

    Default interface methods can have bodies using either block or expression-bodied syntax.
  2. Step 2: Identify correct syntax among options

    void Show() => Console.WriteLine("Hello"); uses expression-bodied syntax correctly inside interface method declaration.
  3. Final Answer:

    void Show() => Console.WriteLine("Hello"); -> Option D
  4. Quick Check:

    Default method syntax = method with body in interface [OK]
Hint: Default methods have bodies, unlike abstract declarations [OK]
Common Mistakes:
  • Using 'default' keyword before method
  • Omitting method body
  • Writing method body without braces or expression syntax
3. What will be the output of this code?
interface IExample { void Show() => Console.WriteLine("Default"); }
class Test : IExample { }
var t = new Test();
t.Show();
medium
A. Runtime error
B. Compilation error: Show() not implemented
C. Default
D. No output

Solution

  1. Step 1: Check if class implements Show()

    Class Test does not implement Show(), but interface provides default implementation.
  2. Step 2: Understand default method usage

    Since Test inherits IExample, it uses the default Show() method from interface.
  3. Final Answer:

    Default -> Option C
  4. Quick Check:

    Default method runs if not overridden [OK]
Hint: If not overridden, default interface method runs [OK]
Common Mistakes:
  • Assuming missing implementation causes error
  • Expecting runtime error without override
  • Thinking interface methods can't have bodies
4. Identify the error in this code snippet:
interface ICalc { int Add(int a, int b) => a + b; }
class Calc : ICalc { public int Add(int a, int b); }
medium
A. Missing method body in Calc's Add method
B. Interface cannot have method bodies
C. Calc class must be abstract
D. Add method should be static

Solution

  1. Step 1: Check Calc class Add method declaration

    Calc declares Add with a semicolon but no body, which is invalid in a class.
  2. Step 2: Understand method implementation requirements

    Class methods must have bodies unless abstract; here Add is not abstract, so body is required.
  3. Final Answer:

    Missing method body in Calc's Add method -> Option A
  4. Quick Check:

    Class methods need bodies unless abstract [OK]
Hint: Class methods need bodies unless marked abstract [OK]
Common Mistakes:
  • Thinking interface can't have bodies
  • Forgetting to add method body in class
  • Assuming method should be static
5. Given this interface and classes:
interface ILogger { void Log(string msg) => Console.WriteLine($"Log: {msg}"); }
class FileLogger : ILogger { public void Log(string msg) => Console.WriteLine($"File: {msg}"); }
class ConsoleLogger : ILogger { }

What will be the output of:
ILogger logger1 = new FileLogger();
ILogger logger2 = new ConsoleLogger();
logger1.Log("Test1");
logger2.Log("Test2");
hard
A. File: Test1 File: Test2
B. File: Test1 Log: Test2
C. Log: Test1 Log: Test2
D. Compilation error

Solution

  1. Step 1: Analyze FileLogger's Log method

    FileLogger overrides Log to print "File: {msg}".
  2. Step 2: Analyze ConsoleLogger's Log method

    ConsoleLogger does not override Log, so uses interface default "Log: {msg}".
  3. Step 3: Predict output for each logger

    logger1.Log("Test1") prints "File: Test1"; logger2.Log("Test2") prints "Log: Test2".
  4. Final Answer:

    File: Test1 Log: Test2 -> Option B
  5. Quick Check:

    Override changes output; default runs if no override [OK]
Hint: Override changes output; default runs if no override [OK]
Common Mistakes:
  • Assuming both use default method
  • Expecting compilation error due to default method
  • Confusing which method runs