Shallow Copy vs Deep Copy in Python
In Python, shallow copy and deep copy are ways of copying objects, but they differ in how they handle nested objects like lists or dictionaries within the copied object.
Shallow Copy
A shallow copy creates a new object but does not create copies of the objects that are contained within it. Instead, it references the original nested objects.
- Behavior:
- The outer object is duplicated.
- Inner objects (e.g., lists, dictionaries) are still references to the same objects in memory.
- Use Case:
- Use a shallow copy when the inner objects don’t need to be modified independently of the original.
- How to Create:
- Using the
copy
module’scopy()
function. - Using the
.copy()
method for certain collections (like lists or dictionaries). - Using slicing for lists (
new_list = old_list[:]
).
- Using the
Example:
import copy
original_list = [[1, 2, 3], [4, 5, 6]]
shallow_copy = copy.copy(original_list)
# Modifying inner list in shallow copy
shallow_copy[0][0] = 99
print("Original List:", original_list) # [[99, 2, 3], [4, 5, 6]]
print("Shallow Copy:", shallow_copy) # [[99, 2, 3], [4, 5, 6]]
Explanation:
Modifying the inner list in shallow_copy affects original_list because both point to the same inner objects.
Deep Copy
A deep copy creates a new object along with recursively copying all objects within it. The new object is entirely independent of the original.
-
Behavior:
- Both the outer object and all nested objects are duplicated.
- Use Case:
- Use a deep copy when changes to the copied object (including its inner objects) should not affect the original object.
-
How to Create:
- Using the
copy
module’sdeepcopy()
function.
- Using the
Example:
import copy
original_list = [[1, 2, 3], [4, 5, 6]]
deep_copy = copy.deepcopy(original_list)
# Modifying inner list in deep copy
deep_copy[0][0] = 99
print("Original List:", original_list) # [[1, 2, 3], [4, 5, 6]]
print("Deep Copy:", deep_copy) # [[99, 2, 3], [4, 5, 6]]
Explanation:
- Modifying the inner list in deep_copy does not affect original_list because all inner objects were copied.
Comparison Table
Fature | Shallow Copy | Deep Copy |
---|---|---|
Outer Object | Copied | Copied |
Inner Objects | References to original | Completely new copies |
Impact of Changes | Changes in inner objects affect original | Changes in inner objects do not affect original |
Performance | Faster | Slower |
Practical Use Case Examples
Use Case for Shallow Copy
- Scenario: A list of employees with unique IDs but the same default settings.
- Reason: You don’t need to copy the inner object (settings), as it’s shared across all employees.
default_settings = {"theme": "dark", "notifications": True}
employees = [{"id": 1, "settings": default_settings}, {"id": 2, "settings": default_settings}]
shallow_copied_employees = employees.copy()
shallow_copied_employees[0]["settings"]["theme"] = "light"
print(employees[0]["settings"]["theme"]) # Output: light (shared settings modified)
Use Case for Deep Copy
- Scenario: A simulation where each user’s settings evolve independently over time.
- Reason: The inner objects (settings) should not be shared.
import copy
default_settings = {"theme": "dark", "notifications": True}
employees = [{"id": 1, "settings": default_settings}, {"id": 2, "settings": default_settings}]
deep_copied_employees = copy.deepcopy(employees)
deep_copied_employees[0]["settings"]["theme"] = "light"
print(employees[0]["settings"]["theme"]) # Output: dark (original unaffected)
Final Thoughts
- Use shallow copy when:
- Performance is critical.
- You want to share inner objects between copies.
- Use deep copy when:
- Independence of all objects is essential.
- Modifications in the copy should not affect the original.
Leave a comment