Bird
Raised Fist0
Javaprogramming~5 mins

Constructor chaining 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: Constructor chaining
O(n)
Understanding Time Complexity

Constructor chaining means one constructor calls another in the same class. We want to see how this affects the time it takes to create an object.

How does the number of constructor calls grow when chaining happens?

Scenario Under Consideration

Analyze the time complexity of the following code snippet.


public class Box {
    int width, height, depth;

    public Box() {
        this(1, 1, 1); // calls the 3-parameter constructor
    }

    public Box(int w, int h, int d) {
        width = w;
        height = h;
        depth = d;
    }
}
    

This code shows one constructor calling another to set default values.

Identify Repeating Operations

Identify the loops, recursion, array traversals that repeat.

  • Primary operation: Constructor call chaining (one constructor calls another exactly once)
  • How many times: Each constructor calls another only once, so the chain length is fixed and small.
How Execution Grows With Input

Execution grows by the number of constructor calls in the chain, which is fixed here.

Input Size (n)Approx. Operations
1 (one object)2 constructor calls
10 (ten objects)20 constructor calls
100 (hundred objects)200 constructor calls

Pattern observation: The number of constructor calls grows linearly with the number of objects created, but each object creation involves a fixed small chain of calls.

Final Time Complexity

Time Complexity: O(n)

This means creating n objects with constructor chaining takes time proportional to n, since each object requires a fixed number of constructor calls.

Common Mistake

[X] Wrong: "Constructor chaining makes object creation take much longer because it repeats many times."

[OK] Correct: The chain length is fixed and small, so it adds only a constant extra cost per object, not a growing cost.

Interview Connect

Understanding constructor chaining helps you explain object creation clearly and shows you know how code structure affects performance in simple ways.

Self-Check

"What if the constructor chain was longer or recursive? How would the time complexity change?"

Practice

(1/5)
1. What is the main purpose of constructor chaining in Java?
easy
A. To allow one constructor to call another constructor in the same class
B. To inherit constructors from a parent class automatically
C. To create multiple objects with the same constructor
D. To override constructors with different names

Solution

  1. Step 1: Understand constructor chaining concept

    Constructor chaining means one constructor calls another constructor in the same class to reuse code.
  2. Step 2: Identify the correct purpose

    To allow one constructor to call another constructor in the same class correctly describes this behavior using this(...) to call another constructor.
  3. Final Answer:

    To allow one constructor to call another constructor in the same class -> Option A
  4. Quick Check:

    Constructor chaining = calling another constructor [OK]
Hint: Constructor chaining uses this(...) to call another constructor [OK]
Common Mistakes:
  • Confusing constructor chaining with inheritance
  • Thinking constructors can have different names
  • Believing constructor chaining creates multiple objects
2. Which of the following is the correct syntax to chain constructors in Java?
easy
A. this.call(); // calls another method
B. super(); // calls constructor of same class
C. this(); // must be the first statement in constructor
D. constructor(); // calls constructor by name

Solution

  1. Step 1: Recall syntax for constructor chaining

    Constructor chaining uses this(...) as the first statement inside a constructor.
  2. Step 2: Identify correct option

    this(); // must be the first statement in constructor shows this(); which is the correct syntax to call another constructor in the same class.
  3. Final Answer:

    this(); // must be the first statement in constructor -> Option C
  4. Quick Check:

    Constructor chaining syntax = this() first [OK]
Hint: Use this() as first line to chain constructors [OK]
Common Mistakes:
  • Using super() to call same class constructor
  • Calling constructor by its name directly
  • Placing this() after other statements
3. What will be the output of the following Java code?
class Test {
  Test() {
    this(5);
    System.out.print("A");
  }
  Test(int x) {
    System.out.print("B");
  }
  public static void main(String[] args) {
    new Test();
  }
}
medium
A. AB
B. BA
C. A
D. B

Solution

  1. Step 1: Trace constructor calls

    Creating new Test() calls the no-arg constructor, which calls Test(int x) first (prints "B"), then prints "A".
  2. Step 2: Determine output order

    Since Test(int x) prints "B" first, then control returns to no-arg constructor which prints "A", output is "BA".
  3. Final Answer:

    BA -> Option B
  4. Quick Check:

    Constructor chaining prints B then A [OK]
Hint: Constructor chaining prints inner constructor output first [OK]
Common Mistakes:
  • Assuming outer constructor prints before inner
  • Confusing order of constructor calls
  • Ignoring that this() must be first line
4. Identify the error in the following Java code related to constructor chaining:
class Sample {
  Sample() {
    System.out.println("Hello");
    this(10);
  }
  Sample(int x) {
    System.out.println(x);
  }
}
medium
A. Constructor chaining call this(10) must be the first statement
B. Constructor name must match class name
C. Cannot overload constructors with different parameters
D. Missing return type in constructors

Solution

  1. Step 1: Check constructor chaining rules

    In Java, the call to another constructor using this(...) must be the first statement in the constructor.
  2. Step 2: Identify the error

    Here, System.out.println("Hello") comes before this(10);, which violates the rule.
  3. Final Answer:

    Constructor chaining call this(10) must be the first statement -> Option A
  4. Quick Check:

    this() must be first line in constructor [OK]
Hint: this() call must be first statement in constructor [OK]
Common Mistakes:
  • Placing code before this() call
  • Confusing constructor overloading with chaining
  • Thinking constructors need return types
5. Given the class below, what will be the output when new Box(); is executed?
class Box {
  Box() {
    this(3, 4);
    System.out.print("X");
  }
  Box(int w, int h) {
    this(w, h, 5);
    System.out.print("Y");
  }
  Box(int w, int h, int d) {
    System.out.print("Z");
  }
}
hard
A. ZXY
B. ZY
C. XYZ
D. ZYX

Solution

  1. Step 1: Trace constructor chaining calls

    Calling new Box() calls no-arg constructor, which calls Box(int w, int h), which calls Box(int w, int h, int d).
  2. Step 2: Track printed characters in order

    The deepest constructor prints "Z" first, then returns to middle constructor which prints "Y", then returns to no-arg constructor which prints "X".
  3. Final Answer:

    ZYX -> Option D
  4. Quick Check:

    Chained constructors print Z then Y then X [OK]
Hint: Deepest constructor prints first, then unwind chain [OK]
Common Mistakes:
  • Assuming outer constructor prints first
  • Ignoring chaining order
  • Mixing up print order in nested calls