通过实现__getitem__、__setitem__、__delitem__、__contains__、__iter__和__len__方法,可使自定义类模拟字典行为,支持键访问、赋值、删除、成员检测、迭代与长度计算,如MyDict示例所示。

Python 中字典(dict)的底层行为由一系列“魔法方法”控制,这些方法以双下划线开头和结尾,也称为“特殊方法”或“dunder 方法”。当我们自定义类并希望模拟字典的行为时,可以通过实现这些方法来让对象像 dict 一样工作。
__getitem__
这个方法用于实现通过键访问值的操作,比如 d['key']。
当你执行 obj[key] 时,Python 会自动调用 __getitem__(key)。示例:
class MyDict:
def __init__(self):
self.data = {}
def __getitem__(self, key):
return self.data[key]
d = MyDict()
d.data['name'] = 'Alice'
print(d['name']) # 输出: Alice
__setitem__
用于实现设置键值对的操作,例如 d['key'] = value。
立即学习“Python免费学习笔记(深入)”;
当执行 obj[key] = value 时,Python 调用 __setitem__(key, value)。更新上面的例子:
def __setitem__(self, key, value):
self.data[key] = value
d['age'] = 25 # 调用 setitem
__delitem__
支持使用 del obj[key] 删除某个键值对。
对应方法是 __delitem__(key)。例如:
def __delitem__(self, key):
del self.data[key]
del d['age'] # 调用 delitem
__contains__
控制 key in obj 的行为。
默认情况下,如果实现了 __getitem__,Python 可能通过捕获异常判断是否存在,但显式实现更高效、清晰。示例:
def __contains__(self, key):
return key in self.data
print('name' in d) # True
__iter__ 和 __len__
让自定义字典支持迭代和 len() 函数。
- __iter__:返回一个可迭代对象,通常 yield 键
- __len__:返回键值对的数量
实现:
def __iter__(self):
return iter(self.data)
def len(self):
return len(self.data)
for k in d: # 可迭代
print(k)
print(len(d)) # 输出长度
其他相关方法(可选)
虽然不是必须,但完整模拟 dict 行为时可以考虑:
- __repr__:定义对象的字符串表示
- keys, values, items:可手动实现这些方法,返回对应的视图对象
- get, pop, clear 等:非魔法方法,但常用于接口一致性
基本上就这些。通过实现 __getitem__、__setitem__、__delitem__、__contains__、__iter__ 和 __len__,你就能创建一个行为接近原生 dict 的类。不复杂但容易忽略细节。











