这是否意味着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