在Blinker的源码里看到一个defaultdict实现,记录下来1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 class defaultdict (dict) : def __init__ (self, default_factory=None, *a, **kw) : if (default_factory is not None and not hasattr(default_factory, '__call__' )): raise TypeError('first argument must be callable' ) dict.__init__(self, *a, **kw) self.default_factory = default_factory def __getitem__ (self, key) : try : return dict.__getitem__(self, key) except KeyError: return self.__missing__(key) def __missing__ (self, key) : if self.default_factory is None : raise KeyError(key) self[key] = value = self.default_factory() return value def __reduce__ (self) : if self.default_factory is None : args = tuple() else : args = self.default_factory, return type(self), args, None , None , self.items() def copy (self) : return self.__copy__() def __copy__ (self) : return type(self)(self.default_factory, self) def __deepcopy__ (self, memo) : import copy return type(self)(self.default_factory, copy.deepcopy(self.items())) def __repr__ (self) : return 'defaultdict(%s, %s)' % (self.default_factory, dict.__repr__(self))