Abstract vs concrete classes in Java - Performance Comparison
Start learning this pattern below
Jump into concepts and practice - no test required
Let's explore how using abstract and concrete classes affects the time it takes for a program to run.
We want to see how the program's steps grow when we use these classes.
Analyze the time complexity of the following code snippet.
abstract class Animal {
abstract void sound();
}
class Dog extends Animal {
void sound() {
System.out.println("Bark");
}
}
public class Main {
public static void main(String[] args) {
Animal a = new Dog();
a.sound();
}
}
This code defines an abstract class and a concrete subclass, then calls a method through the abstract reference.
Identify the loops, recursion, array traversals that repeat.
- Primary operation: Calling the
sound()method once. - How many times: Exactly one time in this example.
Since the method call happens once, the time does not grow with input size.
| Input Size (n) | Approx. Operations |
|---|---|
| 10 | 1 |
| 100 | 1 |
| 1000 | 1 |
Pattern observation: The time stays the same no matter how many objects or calls you might have in a bigger program.
Time Complexity: O(1)
This means the program takes the same amount of time regardless of input size when calling methods on abstract or concrete classes.
[X] Wrong: "Using abstract classes makes the program slower because of extra steps."
[OK] Correct: Calling methods through abstract classes uses normal method calls and does not add noticeable time compared to concrete classes.
Understanding how abstract and concrete classes affect performance helps you write clean code without worrying about slowdowns.
"What if we added a loop that calls sound() on a list of 1000 animals? How would the time complexity change?"
Practice
Solution
Step 1: Understand abstract class definition
An abstract class can have methods without implementation (abstract methods) and cannot create objects directly.Step 2: Compare with other options
Concrete classes have full method implementations and can be instantiated. Interfaces differ from abstract classes. Static-only classes are unrelated.Final Answer:
It can have methods without implementation and cannot be instantiated directly. -> Option CQuick Check:
Abstract class = no direct objects [OK]
- Thinking abstract classes can be instantiated
- Confusing abstract classes with interfaces
- Assuming all methods must be implemented
Solution
Step 1: Recall Java syntax for abstract classes
The keyword 'abstract' comes before 'class' followed by the class name.Step 2: Check each option
Only 'abstract class Vehicle {}' matches correct syntax. The other options have incorrect keyword order.Final Answer:
abstract class Vehicle {} -> Option AQuick Check:
abstract keyword before class name [OK]
- Placing 'abstract' after 'class'
- Mixing keyword order
- Omitting 'abstract' keyword
abstract class Animal {
abstract void sound();
}
class Dog extends Animal {
void sound() {
System.out.println("Bark");
}
}
public class Test {
public static void main(String[] args) {
Animal a = new Dog();
a.sound();
}
}Solution
Step 1: Understand class hierarchy and method overriding
Animal is abstract with abstract method sound(). Dog extends Animal and implements sound() printing "Bark".Step 2: Analyze main method execution
Animal reference points to Dog object. Calling a.sound() runs Dog's sound(), printing "Bark".Final Answer:
Bark -> Option DQuick Check:
Abstract method overridden = Dog's output [OK]
- Expecting abstract class method to run
- Thinking abstract class can be instantiated
- Confusing compile and runtime errors
abstract class Shape {
abstract void draw();
}
class Circle extends Shape {
// No draw() method implemented
}
public class Test {
public static void main(String[] args) {
Circle c = new Circle();
c.draw();
}
}Solution
Step 1: Check subclass implementation of abstract methods
Circle extends Shape but does not implement abstract method draw().Step 2: Understand Java rules for abstract methods
A concrete class must implement all abstract methods or be declared abstract itself. Circle is concrete but missing draw().Final Answer:
Circle must implement the abstract method draw() or be declared abstract. -> Option AQuick Check:
Concrete subclass must implement all abstract methods [OK]
- Thinking abstract methods can be skipped
- Assuming abstract class can't have abstract methods
- Believing object creation is the error
Solution
Step 1: Identify need for shared rules with different implementations
Employee types share concept of salary calculation but differ in details.Step 2: Use abstract class with abstract method
Abstract class Employee defines calculateSalary() abstractly. Subclasses implement specific logic.Step 3: Evaluate other options
Create only concrete classes for each employee type without any abstract class. lacks shared abstraction. Use an interface with no methods and concrete classes implementing it. uses interface with no methods, so no contract. Create a concrete Employee class with a fixed calculateSalary() method used by all employees. fixes salary calculation, no variation.Final Answer:
Create an abstract class Employee with an abstract method calculateSalary(), then create concrete subclasses like Manager and Developer implementing it. -> Option BQuick Check:
Abstract class sets rules, subclasses do work [OK]
- Not using abstraction for shared behavior
- Using concrete class with fixed method only
- Interfaces without methods don't enforce contracts
