Swift与Kotlin在排序数组上的表现

我试着在SwiftKotlin整理一个大小为100000000的数组,我可以看到它们之间巨大的性能差距。 对于这个数字, KotlinSwift快了18倍(在我的机器上)。

我记录了一些结果,我发现当大小在10000或更小时,swift会更快,但一旦数量增加, SwiftKotlin相比将显着变慢。

下面是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

上一篇: Swift vs Kotlin performance on sorting array

下一篇: Sort Array and a Corresponding Array