【冷知识】Python的List最多能容纳多少个元素?
程序员文章站
2022-03-23 11:45:31
答案32位的平台(Python)下List最多能有2**31-1个元素,64位的平台(Python)下List最多能有2**63-1个元素。溯源Python最原始的实现是CPython,即用C实现的Python。对于Python中的List元素最多能容纳多少个元素,肯定还得从底层规范上去溯源。先找到Python的List Objects说明:注意看高亮的地方:Py_ssize_t。根据这段描述Py_ssize_t PyList_Size(PyObject *list)Return...
答案
32位的平台(Python)下List最多能有2**31-1个元素,
64位的平台(Python)下List最多能有2**63-1个元素。
溯源
Python最原始的实现是CPython,即用C实现的Python。对于Python中的List元素最多能容纳多少个元素,肯定还得从底层规范上去溯源。
先找到Python的List Objects说明:
注意看高亮的地方:Py_ssize_t。
根据这段描述
Py_ssize_t PyList_Size(PyObject *list)
Return the length of the list object in list; this is equivalent to len(list) on a list object.
可以知道Py_ssize_t的大小实际上限制了Python List的长度,那么继续找Py_ssize_t的定义:
可以看到sys模块下对Py_ssize_t的长度有相关描述,
也就是说:
32位的平台(Python)下List最多能有2**31-1个元素,
64位的平台(Python)下List最多能有2**63-1个元素。
本文地址:https://blog.csdn.net/TracelessLe/article/details/107281279