Answers:
您可以通过以下方法测试哪段代码更快:
% python -mtimeit "l=[]"
10000000 loops, best of 3: 0.0711 usec per loop
% python -mtimeit "l=list()"
1000000 loops, best of 3: 0.297 usec per loop
但是,实际上,这种初始化很可能只是程序的一小部分,因此担心此初始化可能会出错。
可读性是非常主观的。我更喜欢[]
,但是像Alex Martelli这样的一些非常博学的人更喜欢,list()
因为它很明显。
list('')
给[]
而不是['']
?
list('abcd')
,您就会明白所有内容)
list()
本质上比慢[]
,因为
有符号查找(python不能事先知道您是否不只是将列表重新定义为其他内容!),
有函数调用,
然后它必须检查是否传递了可迭代的参数(以便它可以使用其中的元素创建列表)。在我们的情况下没有,但是有“如果”检查
在大多数情况下,速度差异不会产生任何实际差异。
list()
慢于感觉很好[]
!
list()
它只需要检查是否有任何arg……就不会发生“检查是否可迭代”和“使用元素创建列表”;它们仅在有arg的情况下适用。C代码甚至有可能[]
调用与相同的C代码list()
。在任何情况下,与(a)+(b)相比,(c)所涉及的时间都很少。
我并不是很了解,但是根据我的经验,jpcgt实际上是正确的。以下示例:如果我使用以下代码
t = [] # implicit instantiation
t = t.append(1)
在解释器中,然后调用t给我“ t”,不带任何列表,如果我附加其他内容,例如
t = t.append(2)
我收到错误“'NoneType'对象没有属性'append'”。但是,如果我通过以下方式创建列表
t = list() # explicit instantiation
然后就可以了
t.append(1)
修改t
,它不返回任何内容,而是None
您将其分配None
给t
。因此,t
现在参考None
而不是列表。您在这里的错误是写作,t=t.append(1)
而不仅仅是写作t.append(1)
。您会注意到与的行为相同list()
,因此这里没有区别。