Swift与Kotlin在排序数组上的表现
我试着在Swift
和Kotlin
整理一个大小为100000000的数组,我可以看到它们之间巨大的性能差距。 对于这个数字, Kotlin
比Swift
快了18
倍(在我的机器上)。
我记录了一些结果,我发现当大小在10000或更小时,swift会更快,但一旦数量增加, Swift
与Kotlin
相比将显着变慢。
下面是Swift和Kotlin的代码,
迅速
let n = 100000000
var arr = Array(repeating: 0, count: n)
for i in 1...n {
arr[i-1] = Int(arc4random_uniform(UInt32(n)))
}
//Record time before sort
arr.sort()
//Record time after sort
科特林
val n = 100000000
val arr = IntArray(n)
for (i in 1..n) {
arr[i-1] = Random().nextInt(n)
}
//Record time before sort
arr.sort()
//Record time after sort
记录的时间都低于,
迅速
Size: 1000 Time: 0.001 sec
Size: 10000 Time: 0.009 - 0.01 sec
Size: 100000 Time: 0.122 - 0.127 sec
Size: 1000000 Time: 1.392 - 1.409 sec
Size: 10000000 Time: 16.115 - 16.569 sec
Size: 100000000 Time: 187.346 - 187.71 sec
Size: 1000000000 Waited more than 6 minutes and gave up!
科特林
Size: 1000 Time: 0.06 sec
Size: 10000 Time: 0.063 - 0.084 sec
Size: 100000 Time: 0.083 - 0.105 sec
Size: 1000000 Time: 0.23 - 0.501 sec
Size: 10000000 Time: 1.098 - 1.807 sec
Size: 100000000 Time: 10.759 - 11.141 sec
Size: 1000000000 Time: 124.252 - 127.54 sec
所以,在这里你可以看到Swift
在尺寸增加时变得非常缓慢,但是当数量很小时Swift
会更快。
由于MartinR强调要用Swift
release
构建配置进行编译,因此我将其更改为release
并且对于任何数字, Swift
似乎都更快,如下面的结果所示,
使用Build Configuration作为发布版Swift
Size: 1000 Time: 0.001 sec
Size: 10000 Time: 0.001 sec
Size: 100000 Time: 0.006 - 0.007 sec
Size: 1000000 Time: 0.076 - 0.081 sec
Size: 10000000 Time: 0.891 - 0.898 sec
Size: 100000000 Time: 9.01 - 10.14 sec
Size: 1000000000 Time: 113.87 - 117.285 sec
这可能有助于某人在执行某种性能基准时检查release
构建配置中的Swift
结果,如上所示,结果在调试和发布配置中显着不同。
在调试和发布配置中,编译器使用不同的优化级别,因此会影响性能。 关于优化级别的一些讨论可以在这个问题中找到
链接地址: http://www.djcxy.com/p/31683.html