调用removeLast非常慢(弹出77k元素需要几分钟).
documentation说O(1),我认为实现只会减少数组大小.显然不是:
为什么调用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秒.
解决方法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。