Bird
Raised Fist0
Pythonprogramming~5 mins

Object lifecycle overview 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: Object lifecycle overview
O(n)
Understanding Time Complexity

When we create and use objects in Python, some steps happen behind the scenes. Understanding how long these steps take helps us write better programs.

We want to know how the time to create, use, and delete objects changes as we work with more objects.

Scenario Under Consideration

Analyze the time complexity of the following code snippet.


class MyObject:
    def __init__(self, value):
        self.value = value

objects = []
n = 10  # Example value for n
for i in range(n):
    obj = MyObject(i)
    objects.append(obj)
    

This code creates n objects and stores them in a list.

Identify Repeating Operations
  • Primary operation: Creating an object and adding it to a list.
  • How many times: This happens once for each number from 0 to n-1, so n times.
How Execution Grows With Input

Each new object takes a small, similar amount of time to create and store.

Input Size (n)Approx. Operations
10About 10 object creations and list adds
100About 100 object creations and list adds
1000About 1000 object creations and list adds

Pattern observation: The work grows evenly as we add more objects; doubling n doubles the work.

Final Time Complexity

Time Complexity: O(n)

This means the time to create and store objects grows directly with the number of objects.

Common Mistake

[X] Wrong: "Creating many objects happens instantly and does not add up."

[OK] Correct: Each object takes time to create and store, so many objects add up to more time.

Interview Connect

Understanding how object creation time grows helps you explain program speed and resource use clearly, a useful skill in many coding discussions.

Self-Check

"What if we added a nested loop inside the object creation that also runs n times? How would the time complexity change?"

Practice

(1/5)
1. What is the first step in the lifecycle of a Python object?
easy
A. Creation of the object in memory
B. Deletion of the object
C. Garbage collection
D. Assignment of a variable

Solution

  1. Step 1: Understand object lifecycle start

    The lifecycle of a Python object begins when it is created in memory.
  2. Step 2: Differentiate from other lifecycle stages

    Deletion and garbage collection happen later, after creation and use.
  3. Final Answer:

    Creation of the object in memory -> Option A
  4. Quick Check:

    Object lifecycle starts with creation [OK]
Hint: Object lifecycle always starts with creation [OK]
Common Mistakes:
  • Confusing creation with deletion
  • Thinking garbage collection happens first
  • Assuming variable assignment is the first step
2. Which of the following is the correct syntax to define a destructor method in a Python class?
easy
A. def destructor(self):
B. def __del__(self):
C. def delete(self):
D. def __destroy__(self):

Solution

  1. Step 1: Recall destructor method name

    In Python, the destructor method is named __del__ with double underscores before and after.
  2. Step 2: Check syntax correctness

    The correct syntax is def __del__(self): which matches Python's special method naming.
  3. Final Answer:

    def __del__(self): -> Option B
  4. Quick Check:

    Destructor method = __del__ [OK]
Hint: Destructor method is always named __del__ [OK]
Common Mistakes:
  • Using wrong method names like destructor or delete
  • Missing double underscores
  • Confusing with constructor __init__
3. What will be the output of the following code?
class MyClass:
    def __init__(self):
        print('Created')
    def __del__(self):
        print('Deleted')

obj = MyClass()
print('Object in use')
del obj
print('End')
medium
A. Created\nObject in use\nDeleted\nEnd
B. Created\nDeleted\nObject in use\nEnd
C. Object in use\nCreated\nDeleted\nEnd
D. Created\nObject in use\nEnd

Solution

  1. Step 1: Trace object creation and constructor call

    When obj = MyClass() runs, __init__ prints 'Created'.
  2. Step 2: Follow print and deletion order

    Next, 'Object in use' prints. Then del obj calls __del__, printing 'Deleted'. Finally, 'End' prints.
  3. Final Answer:

    Created\nObject in use\nDeleted\nEnd -> Option A
  4. Quick Check:

    Constructor then prints, then destructor after del [OK]
Hint: Destructor runs only after del or object goes out of scope [OK]
Common Mistakes:
  • Assuming destructor runs immediately after creation
  • Ignoring order of print statements
  • Thinking del obj skips destructor
4. Identify the error in this code related to object lifecycle:
class Sample:
    def __init__(self):
        print('Init called')
    def __del__(self):
        print('Del called')

obj = Sample()
obj = None
print('Done')
medium
A. Destructor __del__ will not be called because obj is set to None
B. Syntax error in class definition
C. No error; destructor will be called when obj is set to None
D. Constructor __init__ will not be called

Solution

  1. Step 1: Understand what happens when obj is set to None

    Setting obj = None removes the reference to the Sample object, so it becomes eligible for garbage collection.
  2. Step 2: Confirm destructor call behavior

    When no references remain, __del__ is called, so 'Del called' will print before 'Done'.
  3. Final Answer:

    No error; destructor will be called when obj is set to None -> Option C
  4. Quick Check:

    Destructor runs when object has no references [OK]
Hint: Destructor runs when last reference is removed [OK]
Common Mistakes:
  • Thinking setting variable to None skips destructor
  • Confusing syntax errors with lifecycle behavior
  • Assuming constructor is skipped
5. Given a list of objects created inside a function, when will their destructors be called?
class Item:
    def __init__(self, name):
        self.name = name
        print(f'Created {name}')
    def __del__(self):
        print(f'Deleted {self.name}')

def create_items():
    items = [Item('a'), Item('b'), Item('c')]
    print('Items created')

create_items()
print('Function ended')
hard
A. Destructors called immediately after 'Items created' inside the function
B. Destructors called before 'Items created'
C. Destructors never called because list holds references
D. Destructors called after 'Function ended' when function scope ends

Solution

  1. Step 1: Analyze object references inside function

    Objects are stored in the list 'items' inside create_items(). They exist until the function ends.
  2. Step 2: Determine when objects lose references

    When create_items() finishes, 'items' list is destroyed, removing references to objects, triggering destructors.
  3. Step 3: Confirm output order

    So, 'Items created' prints, then function ends, then destructors print, then 'Function ended' prints.
  4. Final Answer:

    Destructors called after 'Function ended' when function scope ends -> Option D
  5. Quick Check:

    Objects destroyed after function scope ends [OK]
Hint: Objects destroyed when last reference goes out of scope [OK]
Common Mistakes:
  • Thinking destructors run immediately after creation
  • Assuming list keeps objects alive forever
  • Confusing print order with destructor timing