Bird
Raised Fist0
Pythonprogramming~30 mins

Object lifecycle overview in Python - Mini Project: Build & Apply

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
Object lifecycle overview
📖 Scenario: Imagine you have a simple program that creates and uses a Car object. You want to understand how this object is created, used, and then removed from memory.
🎯 Goal: You will write a small program that creates a Car object, uses it, and then shows when the object is deleted. This will help you see the full lifecycle of an object in Python.
📋 What You'll Learn
Create a class called Car with an __init__ method
Add a method called drive that prints a message
Create an instance of Car called my_car
Call the drive method on my_car
Delete the my_car object and show a message when it is deleted
💡 Why This Matters
🌍 Real World
Understanding object lifecycle helps in managing resources like memory and files in real programs.
💼 Career
Knowing how objects are created and destroyed is important for writing efficient and bug-free code in software development.
Progress0 / 4 steps
1
Create the Car class with an __init__ method
Create a class called Car with an __init__ method that prints "Car created" when a new object is made.
Python
Hint

The __init__ method runs when you create a new object.

2
Add a drive method to the Car class
Add a method called drive inside the Car class that prints "Car is driving" when called.
Python
Hint

Methods inside a class always have self as the first parameter.

3
Create a Car object and call the drive method
Create an object called my_car from the Car class. Then call the drive method on my_car.
Python
Hint

Use my_car = Car() to create the object and my_car.drive() to call the method.

4
Delete the Car object and show a message
Add a __del__ method to the Car class that prints "Car deleted" when the object is removed. Then delete the my_car object using del my_car.
Python
Hint

The __del__ method runs when the object is deleted with del.

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