Bird
Raised Fist0
Pythonprogramming~5 mins

Extending built-in exceptions in Python - 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: Extending built-in exceptions
O(n)
Understanding Time Complexity

When we extend built-in exceptions in Python, we add custom behavior to error handling.

We want to see how the time to create and raise these exceptions changes as input grows.

Scenario Under Consideration

Analyze the time complexity of this custom exception class and its usage.


class MyError(Exception):
    def __init__(self, message, code):
        super().__init__(message)
        self.code = code


def check_value(x):
    if x < 0:
        raise MyError('Negative value', x)
    return x
    

This code defines a new error type and raises it when a value is negative.

Identify Repeating Operations

Look for loops or repeated actions that affect time.

  • Primary operation: Creating and raising the custom exception.
  • How many times: Once per call to check_value when input is negative.
How Execution Grows With Input

Each call to check_value does a simple check and may raise an exception.

Input Size (n)Approx. Operations
1010 checks, few exceptions if any
100100 checks, exceptions only when input is negative
10001000 checks, exceptions rare or frequent based on input

Pattern observation: Time grows linearly with number of calls, exception creation cost is constant per raise.

Final Time Complexity

Time Complexity: O(n)

This means the time grows directly with how many times you call the function, since each call does a simple check.

Common Mistake

[X] Wrong: "Creating a custom exception makes the program slower exponentially."

[OK] Correct: Creating and raising exceptions takes constant time each time, so it does not grow exponentially with input size.

Interview Connect

Understanding how custom exceptions affect performance helps you write clear and efficient error handling in real projects.

Self-Check

What if the exception included a large data structure as a property? How would the time complexity change?

Practice

(1/5)
1. What is the main reason to extend built-in exceptions in Python?
easy
A. To create custom error types that describe specific problems clearly
B. To make the program run faster
C. To avoid using try-except blocks
D. To automatically fix errors when they occur

Solution

  1. Step 1: Understand the purpose of exceptions

    Exceptions help signal errors or unusual situations in a program.
  2. Step 2: Why extend built-in exceptions?

    Extending allows creating specific error types that explain problems clearly and help debugging.
  3. Final Answer:

    To create custom error types that describe specific problems clearly -> Option A
  4. Quick Check:

    Custom exceptions = clearer error messages [OK]
Hint: Custom exceptions clarify errors, not speed or auto-fix [OK]
Common Mistakes:
  • Thinking extending exceptions speeds up code
  • Believing exceptions fix errors automatically
  • Confusing exceptions with avoiding try-except
2. Which of the following is the correct way to define a custom exception named MyError that extends ValueError?
easy
A. def MyError(ValueError): pass
B. class MyError(ValueError): pass
C. class MyError: ValueError
D. exception MyError(ValueError): pass

Solution

  1. Step 1: Recognize class syntax for exceptions

    Custom exceptions are classes that inherit from built-in exceptions.
  2. Step 2: Check correct Python class definition

    Use class MyError(ValueError): pass to extend ValueError properly.
  3. Final Answer:

    class MyError(ValueError): pass -> Option B
  4. Quick Check:

    Use class + inheritance syntax for exceptions [OK]
Hint: Use class keyword and inherit from built-in exception [OK]
Common Mistakes:
  • Using def instead of class
  • Wrong inheritance syntax
  • Using 'exception' keyword which doesn't exist
3. What will be the output of this code?
class MyError(Exception):
    pass

try:
    raise MyError('Oops!')
except MyError as e:
    print(e)
medium
A. MyError
B. Exception
C. Oops!
D. No output

Solution

  1. Step 1: Understand raising and catching custom exception

    The code raises MyError with message 'Oops!'.
  2. Step 2: What does print(e) show?

    Printing the exception variable e shows the message passed during raise.
  3. Final Answer:

    Oops! -> Option C
  4. Quick Check:

    Exception message prints when caught and printed [OK]
Hint: Print exception object to see its message [OK]
Common Mistakes:
  • Printing exception class name instead of message
  • Expecting no output because of exception
  • Confusing exception type with message
4. Identify the error in this custom exception definition:
class CustomError(Exception):
    def __init__(self, message):
        print(message)
medium
A. Exception cannot be extended
B. Class name should be lowercase
C. print() cannot be used in __init__
D. Missing call to super().__init__(message) in __init__

Solution

  1. Step 1: Check __init__ method in custom exception

    Custom exceptions should call the parent Exception __init__ to set the message properly.
  2. Step 2: Why call super().__init__(message)?

    This ensures the message is stored and accessible like normal exceptions.
  3. Final Answer:

    Missing call to super().__init__(message) in __init__ -> Option D
  4. Quick Check:

    Always call super().__init__ in custom exception init [OK]
Hint: Call super().__init__ to set message in custom exceptions [OK]
Common Mistakes:
  • Forgetting super().__init__ call
  • Thinking print replaces message storage
  • Believing class names must be lowercase
5. You want to create a custom exception ValidationError that stores an error code along with the message. Which code correctly implements this?
hard
A. class ValidationError(Exception): def __init__(self, message, code): super().__init__(message) self.code = code
B. class ValidationError(Exception): def __init__(self, message, code): self.message = message self.code = code
C. class ValidationError(Exception): def __init__(self, code): super().__init__(code) self.message = ''
D. class ValidationError(Exception): def __init__(self, message): super().__init__(message) self.code = None

Solution

  1. Step 1: Understand storing extra info in custom exceptions

    We want to keep both message and code, so __init__ must accept both.
  2. Step 2: Properly call super().__init__ with message and store code

    class ValidationError(Exception): def __init__(self, message, code): super().__init__(message) self.code = code calls super().__init__(message) to set message and saves code as attribute.
  3. Final Answer:

    class ValidationError(Exception): def __init__(self, message, code): super().__init__(message) self.code = code -> Option A
  4. Quick Check:

    Call super with message, store extra attributes separately [OK]
Hint: Call super with message, save extra data as attributes [OK]
Common Mistakes:
  • Not calling super().__init__ with message
  • Not storing extra info as attributes
  • Mixing message and code parameters