Creating exception classes in Python - Performance & Efficiency
Start learning this pattern below
Jump into concepts and practice - no test required
When we create custom exception classes in Python, we want to know how the time it takes to create and use these classes changes as our program grows.
We ask: How does the work needed to handle exceptions grow with more exceptions or more code?
Analyze the time complexity of the following code snippet.
class MyError(Exception):
pass
try:
raise MyError("Something went wrong")
except MyError as e:
print(e)
This code defines a new exception class and uses it to raise and catch an error.
Identify the loops, recursion, array traversals that repeat.
- Primary operation: Creating the exception class and raising it once.
- How many times: The exception is raised and caught only once in this snippet.
Since the exception is raised and caught once, the work stays the same no matter how big the program is.
| Input Size (n) | Approx. Operations |
|---|---|
| 10 | 1 |
| 100 | 1 |
| 1000 | 1 |
Pattern observation: The time to create and use this exception does not grow with input size; it stays constant.
Time Complexity: O(1)
This means the time to create and use the exception class stays the same no matter how big the program or input is.
[X] Wrong: "Creating a new exception class slows down the program as it grows."
[OK] Correct: Defining an exception class is a one-time setup and raising it once takes constant time, so it does not slow down the program as it grows.
Understanding how exception classes work and their time cost helps you write clear and efficient error handling in real projects.
"What if we raised the exception inside a loop that runs n times? How would the time complexity change?"
Practice
Solution
Step 1: Understand how to define a class inheriting Exception
Custom exceptions must inherit from the built-in Exception class to behave like errors.Step 2: Check syntax correctness
class MyError(Exception): pass correctly defines a class named MyError inheriting from Exception with pass inside.Final Answer:
class MyError(Exception): pass -> Option CQuick Check:
Custom exception class = class MyError(Exception): pass [OK]
- Not inheriting from Exception
- Using def instead of class
- Wrong keyword like 'exception' instead of 'class'
MyError?Solution
Step 1: Recall the Python keyword to raise exceptions
Python uses the keyword 'raise' to trigger exceptions, not 'throw'.Step 2: Check the syntax for raising a custom exception
Correct syntax is 'raise MyError()' to create and raise the exception instance.Final Answer:
raise MyError() -> Option AQuick Check:
Raise custom error = raise MyError() [OK]
- Using 'throw' instead of 'raise'
- Adding 'new' keyword like in other languages
- Not calling the exception as a function
class MyError(Exception):
pass
try:
raise MyError("Oops!")
except MyError as e:
print(e)Solution
Step 1: Understand the raise statement with message
The code raises MyError with the message 'Oops!'.Step 2: Catch the exception and print its message
The except block catches MyError as 'e' and prints 'e', which outputs the message 'Oops!'.Final Answer:
Oops! -> Option AQuick Check:
Exception message prints = Oops! [OK]
- Printing exception class name instead of message
- Not catching the exception properly
- Expecting no output
class MyError(Exception):
pass
try:
raise MyError
except MyError:
print("Caught error")Solution
Step 1: Check how the exception is raised
In Python, it is valid to raise an exception class without parentheses if it has no __init__ arguments.Step 2: Identify the problem in the code
The code uses 'raise MyError' without parentheses, which is valid and does not raise an error.Final Answer:
No error, code runs fine -> Option BQuick Check:
Raising exception class without parentheses is allowed [OK]
- Omitting parentheses after exception name
- Mismatching exception names in except block
- Incorrect class syntax
ValidationError that stores an error code along with the message. Which code correctly implements this?Solution
Step 1: Understand how to extend Exception with extra attributes
To add an error code, override __init__ and call super().__init__(message) to set the message properly.Step 2: Check which option correctly calls super().__init__ and stores code
class ValidationError(Exception): def __init__(self, message, code): super().__init__(message) self.code = code calls super().__init__(message) and assigns self.code = code, correctly storing both.Final Answer:
class ValidationError(Exception): def __init__(self, message, code): super().__init__(message) self.code = code -> Option DQuick Check:
Call super().__init__(message) and store extra attributes [OK]
- Not calling super().__init__ for message
- Assigning message without super call
- Missing code attribute assignment
