Python enumerate()函数是否提前对元素进行计数?
为了支持在集合上建立索引,Python包含函数。它为集合提供索引Python enumerate()函数是否提前对元素进行计数?,python,list,enumerate,Python,List,Enumerate,为了支持在集合上建立索引,Python包含函数。它为集合提供索引 for index, item in enumerate(list): # do domething print index 在我的例子中,我有一个巨大的列表,我想知道手动创建索引是否更快?e、 g 不,enumerate()没有制作列表的装饰副本。它以类似迭代器的东西作为参数,并返回类似迭代器的东西作为结果,因此它或多或少地完成了“手动”示例所做的工作 内置了枚举功能;它不预先计算元素。下稿内容如下: 因此,函
for index, item in enumerate(list):
# do domething
print index
在我的例子中,我有一个巨大的列表,我想知道手动创建索引是否更快?e、 g
不,enumerate()没有制作列表的装饰副本。它以类似迭代器的东西作为参数,并返回类似迭代器的东西作为结果,因此它或多或少地完成了“手动”示例所做的工作 内置了
枚举
功能;它不预先计算元素。下稿内容如下:
因此,函数会动态生成一个
next
en
整数 枚举怎么可能比这慢呢?这本质上就是它的实现,那么为什么内置的会更慢呢?您甚至链接到了PEP,它提供了天真的实现。
index = 0
for item in list:
# do something
print index
index = index + 1
static PyObject *
enum_next(enumobject *en)
{
PyObject *next_index;
PyObject *next_item;
PyObject *result = en->en_result;
PyObject *it = en->en_sit;
next_item = (*it->ob_type->tp_iternext)(it);
if (next_item == NULL)
return NULL;
next_index = PyInt_FromLong(en->en_index);
if (next_index == NULL) {
Py_DECREF(next_item);
return NULL;
}
en->en_index++;
if (result->ob_refcnt == 1) {
Py_INCREF(result);
Py_DECREF(PyTuple_GET_ITEM(result, 0));
Py_DECREF(PyTuple_GET_ITEM(result, 1));
} else {
result = PyTuple_New(2);
if (result == NULL) {
Py_DECREF(next_index);
Py_DECREF(next_item);
return NULL;
}
}
PyTuple_SET_ITEM(result, 0, next_index);
PyTuple_SET_ITEM(result, 1, next_item);
return result;
}