调用removeLast非常慢(弹出77k元素需要几分钟). documentation说O(1),我认为实现只会减少数组大小.显然不是: removeLast calling memmove" data-src="https://i.stack.imgur.com/zzb0a.png"> 为什么调用remove(at:I
为什么调用remove(at:Int)?
这个repro的情况比我想象的慢(我已经习惯了C的std :: vector性能),但仍然没有我在代码中看到的那么慢:
var array = [ Int ]() for i in 0..<262144 { array.append(i) } print ("done appending") // we get here immediately let n = array.count for _ in 0..<n { array.removeLast() // popLast is also slow } print ("done")
我的机器需要16秒.等效的C程序需要.002秒.
问题在于你的测试方式.调试版本中的速度测试没有任何意义.这就是您应该始终在仪器中进行分析的原因.它使用Release版本.为获得真实的结果,请在设备上的仪器中进行配置其他一切都是幻觉.那么做一个Release版本,而不是一个Debug版本.您将看到实际上您可以立即获得两个打印语句.
结果(在我的电脑上,不是设备,因为我懒得把手机从口袋里掏出来)显示自参考日期以来的秒数:
starting 506917910.056674 done appending 506917910.060245 done 506917910.069827