Bird
Raised Fist0
Javaprogramming~5 mins

Interface declaration in Java - 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: Interface declaration
O(1)
Understanding Time Complexity

When we declare an interface in Java, we want to understand how this affects the program's running time.

We ask: does creating or using an interface change how long the program takes as it grows?

Scenario Under Consideration

Analyze the time complexity of the following code snippet.


public interface Vehicle {
    void start();
    void stop();
}

public class Car implements Vehicle {
    public void start() { System.out.println("Car started"); }
    public void stop() { System.out.println("Car stopped"); }
}
    

This code declares an interface and a class that implements it, defining simple methods.

Identify Repeating Operations

Identify the loops, recursion, array traversals that repeat.

  • Primary operation: There are no loops or repeated operations in interface declaration itself.
  • How many times: The interface methods are declared once; no repetition occurs here.
How Execution Grows With Input

Explain the growth pattern intuitively.

Input Size (n)Approx. Operations
10Constant number of operations
100Still constant, no loops or recursion
1000Constant, interface declaration cost does not grow

Pattern observation: Declaring an interface does not increase operations as input size grows; it stays the same.

Final Time Complexity

Time Complexity: O(1)

This means declaring an interface takes the same amount of time no matter how big the program or input is.

Common Mistake

[X] Wrong: "Declaring an interface makes the program slower as it grows because it adds more code."

[OK] Correct: Declaring an interface is just a blueprint and does not run repeatedly; it does not add time that grows with input size.

Interview Connect

Understanding that interface declarations do not affect time complexity helps you focus on the parts of code that really impact performance.

Self-Check

"What if the interface had default methods with loops inside? How would the time complexity change?"

Practice

(1/5)
1. What is the main purpose of an interface in Java?
easy
A. To inherit code from multiple classes
B. To store data values like variables
C. To create objects directly
D. To declare methods that a class must implement without providing their body

Solution

  1. Step 1: Understand what an interface declares

    An interface only declares method signatures without any implementation.
  2. Step 2: Compare with other options

    Interfaces do not store data, create objects, or inherit code from classes.
  3. Final Answer:

    To declare methods that a class must implement without providing their body -> Option D
  4. Quick Check:

    Interface purpose = declare methods only [OK]
Hint: Interfaces declare methods without bodies [OK]
Common Mistakes:
  • Thinking interfaces can store variables
  • Confusing interfaces with classes
  • Believing interfaces create objects
2. Which of the following is the correct way to declare an interface named Vehicle in Java?
easy
A. interface Vehicle {}
B. class Vehicle interface {}
C. interface Vehicle() {}
D. Vehicle interface {}

Solution

  1. Step 1: Recall Java interface syntax

    Interfaces are declared with the keyword interface followed by the name and curly braces.
  2. Step 2: Check each option

    interface Vehicle {} matches correct syntax: interface Vehicle {}. Others have syntax errors like misplaced parentheses or keywords.
  3. Final Answer:

    interface Vehicle {} -> Option A
  4. Quick Check:

    Correct interface syntax = interface Name {} [OK]
Hint: Use 'interface Name {}' to declare interfaces [OK]
Common Mistakes:
  • Adding parentheses after interface name
  • Mixing class and interface keywords
  • Omitting the 'interface' keyword
3. What will be the output of the following code?
interface Animal {
    void sound();
}

class Dog implements Animal {
    public void sound() {
        System.out.println("Bark");
    }
}

public class Test {
    public static void main(String[] args) {
        Animal a = new Dog();
        a.sound();
    }
}
medium
A. Compilation error
B. sound
C. Bark
D. No output

Solution

  1. Step 1: Understand interface implementation

    The class Dog implements Animal and provides the method sound() which prints "Bark".
  2. Step 2: Trace the main method execution

    In main, an Animal reference points to a Dog object, calling sound() prints "Bark".
  3. Final Answer:

    Bark -> Option C
  4. Quick Check:

    Interface method called prints 'Bark' [OK]
Hint: Implemented method runs when called via interface reference [OK]
Common Mistakes:
  • Expecting interface to print something
  • Missing 'public' in method implementation causing error
  • Thinking no output occurs
4. Identify the error in this interface declaration:
interface Calculator {
    int add(int a, int b) {
        return a + b;
    }
}
medium
A. Interfaces cannot have method bodies unless default or static
B. Method name 'add' is invalid in interfaces
C. Return type 'int' is not allowed in interfaces
D. Interface name must start with lowercase

Solution

  1. Step 1: Check method body rules in interfaces

    In Java, interface methods cannot have bodies unless marked as default or static.
  2. Step 2: Analyze the given method

    The method add has a body but no default or static keyword, causing a syntax error.
  3. Final Answer:

    Interfaces cannot have method bodies unless default or static -> Option A
  4. Quick Check:

    Method bodies in interfaces need default/static [OK]
Hint: Interface methods need default/static for bodies [OK]
Common Mistakes:
  • Adding method bodies without default/static
  • Thinking method names are restricted
  • Ignoring Java naming conventions
5. Given two interfaces:
interface Printable {
    void print();
}

interface Showable {
    void show();
}

class Document implements Printable, Showable {
    public void print() {
        System.out.println("Printing document");
    }
    public void show() {
        System.out.println("Showing document");
    }
}

public class Test {
    public static void main(String[] args) {
        Document doc = new Document();
        doc.print();
        doc.show();
    }
}

What is the output when running Test?
hard
A. Compilation error due to multiple interfaces
B. Printing document\nShowing document
C. Printing document only
D. No output

Solution

  1. Step 1: Understand multiple interface implementation

    Java allows a class to implement multiple interfaces and must provide all their methods.
  2. Step 2: Trace method calls in main

    The Document class implements both methods. Calling print() and show() prints both messages.
  3. Final Answer:

    Printing document\nShowing document -> Option B
  4. Quick Check:

    Multiple interfaces implemented, all methods run [OK]
Hint: Classes can implement many interfaces, all methods must be defined [OK]
Common Mistakes:
  • Thinking multiple interfaces cause errors
  • Forgetting to implement all interface methods
  • Expecting only one method to run