为什么用不同值初始化的范围在python 3中互相比较相等?
当我在解释器中执行以下命令时:
>>> r1 = range(0)
>>> r2 = range(2, 2, 2)
>>> r1 == r2
True
结果是True。为什么会这样?为什么两个参数值不同的range对象被视为相等?
一个简短但不充分的答案也将是"因为两个范围是相等的"。注意is和==之间的区别。
range对象是特殊的:
python将把range对象作为序列进行比较。这实质上意味着,比较并不评估它们如何表示给定的序列,而是评估它们所表示的内容。
start、stop和step参数完全不同的事实在这里没有区别,因为它们在展开时都代表一个空列表:
例如,第一个range对象:
list(range(0)) # []
第二个range对象:
list(range(2, 2, 2)) # []
两者都代表一个空列表,由于两个空列表比较相等(True,所以表示它们的range对象也一样。
因此,您可以拥有完全不同的外观的range对象;如果它们代表相同的序列,它们将比较相等:
range(1, 5, 100) == range(1, 30, 100)
两者都用一个元素[1]表示一个列表,因此这两个元素的比较也相等。不,range对象非常特殊:
但是,请注意,即使比较没有评估它们如何表示序列,也可以仅使用start、step和range对象的len的值来实现比较结果;这对比较速度有着非常有趣的影响:
r0 = range(1, 1000000)
r1 = range(1, 1000000)
l0 = list(r0)
l1 = list(r1)
范围比较超快:
%timeit r0 == r1
The slowest run took 28.82 times longer than the fastest. This could mean that an intermediate result is being cached
10000000 loops, best of 3: 160 ns per loop
另一方面,清单……
%timeit l0 == l1
10 loops, best of 3: 27.8 ms per lo