首页  >  文章  >  后端开发  >  为什么 Python 3.3 后字典排序是非确定性的?

为什么 Python 3.3 后字典排序是非确定性的?

Linda Hamilton
Linda Hamilton原创
2024-10-21 15:22:02337浏览

Why Is Dictionary Ordering Non-Deterministic Post-Python 3.3?

为什么 Python 3.3 中字典排序是非确定性的?

在 3.3 之前的 Python 版本中,字典键的排序是任意的,但是持续的。然而,在 Python 3.3 中,这种顺序变得不确定。

此更改是由 2012 年实施的安全修复程序导致的,并在 Python 3.3 中默认启用。哈希随机化是为了解决安全漏洞而引入的,它会导致字典和集合的迭代顺序不可预测,并且在不同的 Python 运行中会有所不同。

要禁用哈希随机化,您可以将 PYTHONHASHSEED 环境变量设置为 0。

反直觉示例

虽然问题中的反例在 Python 3.3 中并不总是产生相同的结果,但其有限数量的不同排序源于哈希冲突的处理。

Python 3.6 及更高版本中不再存在此限制,始终保留字典的插入顺序。

以上是为什么 Python 3.3 后字典排序是非确定性的?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn