我正在阅读流利的Python,并试图加深对字典的理解。
因此,当我运行以下代码时,结果很容易理解,因为get()和dunder ()都返回相同的结果
sample = {'a':1, 'b':2}
print(sample.__getitem__('a')) # 1
print(sample.get('a')) # 1当我用get()子类dict时,我得到一个工作实例
class MyDict(dict):
def __missing__(self, key):
return 0
def get(self, key):
return self[key]
d = MyDict(sample)
print(d['a']) # 1
print(d['c']) # 0现在,如果我用()替换get(),我会得到一个错误,我不知道原因。
class MyDict2(dict):
def __missing__(self, key):
return 0
def __getitem__(self, key):
return self[key]
d = MyDict2(sample)
print(d['a'])
print(d['c'])错误
RecursionError: maximum recursion depth exceeded while calling a Python object所以问题是,在这种情况下,get和dunder有什么区别,为什么这会导致递归错误?
发布于 2018-05-29 13:27:04
这是因为self[key]在MyDict2.__getitem__(key)中等价于(即调用) self.__getitem__(key) =>无限递归。
发布于 2018-05-29 13:27:11
在……里面
def __getitem__(self, key):
return self[key]self[key]称最低层__getitem__为self[key] .无限递归
在:
def get(self, key):
return self[key]self[key]也调用最低级别的__getitem__,但是从dict类调用,所以它不能恢复:它可以工作(您只是重载了get方法,仅此而已)
https://stackoverflow.com/questions/50585532
复制相似问题