这是否意味着OrderedDict
将变得多余?我能想到的唯一用途是保持与旧版本Python的向后兼容性,而旧版本的Python不保留常规词典的插入顺序。
这是否意味着OrderedDict
将变得多余?我能想到的唯一用途是保持与旧版本Python的向后兼容性,而旧版本的Python不保留常规词典的插入顺序。
Answers:
不,它不会在Python 3.7中变得多余,因为OrderedDict
它不仅dict
保留插入顺序,而且还提供依赖顺序的方法OrderedDict.move_to_end()
,并支持reversed()
迭代*。
此外,与的相等比较OrderedDict
是顺序敏感的,dict
在Python 3.7中仍然不是这种情况,例如:
>>> OrderedDict([(1,1), (2,2)]) == OrderedDict([(2,2), (1,1)])
False
>>> dict([(1,1), (2,2)]) == dict([(2,2), (1,1)])
True
*为Python 3.8添加了reversed()
对常规Python迭代的支持dict
,请参见issue33462