Swift 二维数组性能
Swift 2D Array Performance
我正在为我创建的 Android 应用创建一个 iOS 版本。涉及到很多二维数组的访问和赋值,在Java上运行的非常快。但是,当我转换为 Swift 时,我注意到速度明显下降。在对二维 Swift 数组进行一些研究之后,我认为问题可能出在二维数组上,因此我决定创建并计时一个简单的程序来测试二维数组的性能。我比较了 2D 和 1D 数组的执行时间,发现存在显着差异。下面是我用来测试性能的程序:
import Foundation
var numberOfItems = 1000
var myArray1 = [[Double]](repeating: [Double](repeating: 0.0, count: numberOfItems), count: numberOfItems)
var myArray2 = [[Double]](repeating: [Double](repeating: 0.0, count: numberOfItems), count: numberOfItems)
var myArray3 = [Double](repeating: 0.0, count: numberOfItems * numberOfItems)
var myArray4 = [Double](repeating: 0.0, count: numberOfItems * numberOfItems)
// 2D array assignment
let start1 = CFAbsoluteTimeGetCurrent()
var x = 0.0
for i in 0..<numberOfItems {
for j in 0..<numberOfItems {
myArray1[i][j] = x
x += 1
}
}
let diff1 = CFAbsoluteTimeGetCurrent() - start1
print(diff1 * 1000)
// 2D array access and assignment
let start2 = CFAbsoluteTimeGetCurrent()
for i in 0..<numberOfItems {
for j in 0..<numberOfItems {
myArray2[i][j] = myArray1[i][j]
}
}
let diff2 = CFAbsoluteTimeGetCurrent() - start2
print(diff2 * 1000)
// 1D array assignment
var y = 0.0
let start3 = CFAbsoluteTimeGetCurrent()
for i in 0..<(numberOfItems * numberOfItems) {
myArray3[i] = y
y += 1
}
let diff3 = CFAbsoluteTimeGetCurrent() - start3
print(diff3 * 1000)
// 1D array access and assignment
let start4 = CFAbsoluteTimeGetCurrent()
for i in 0..<(numberOfItems * numberOfItems) {
myArray4[i] = myArray3[i]
}
let diff4 = CFAbsoluteTimeGetCurrent() - start4
print(diff4 * 1000)
我 运行 它在命令行上使用 -Ounchecked 选项。我得到以下输出(以毫秒为单位,有些变化但通常非常接近):
6.0759782791137695
24.2689847946167
2.4139881134033203
1.5819072723388672
显然,二维和一维数组实现之间存在相当大的性能差异,尤其是在访问和分配时。
有没有办法在 Swift 中创建更高效的二维数组?在这种情况下,性能对我来说很重要,所以使用一维数组并为索引做一些数学运算会更好吗?
如果你真的想坚持使用二维数组,那么你可以使用不安全的缓冲区指针来加快访问速度。然而,一维数组仍然会更有效率。试一试。
// 2D array assignment
myArray1.withUnsafeMutableBufferPointer { outer1 -> Void in
for i in 0..<numberOfItems {
outer1[i].withUnsafeMutableBufferPointer { inner1 -> Void in
for j in 0..<numberOfItems {
inner1[j] = x
x += 1
}
}
}
}
// 2D array access and assignment
myArray1.withUnsafeMutableBufferPointer { outer1 -> Void in
myArray2.withUnsafeMutableBufferPointer { outer2 -> Void in
for i in 0..<numberOfItems {
outer1[i].withUnsafeMutableBufferPointer { inner1 -> Void in
outer2[i].withUnsafeMutableBufferPointer { inner2 -> Void in
for j in 0..<numberOfItems {
inner2[j] = inner1[j]
}
}
}
}
}
}
我正在为我创建的 Android 应用创建一个 iOS 版本。涉及到很多二维数组的访问和赋值,在Java上运行的非常快。但是,当我转换为 Swift 时,我注意到速度明显下降。在对二维 Swift 数组进行一些研究之后,我认为问题可能出在二维数组上,因此我决定创建并计时一个简单的程序来测试二维数组的性能。我比较了 2D 和 1D 数组的执行时间,发现存在显着差异。下面是我用来测试性能的程序:
import Foundation
var numberOfItems = 1000
var myArray1 = [[Double]](repeating: [Double](repeating: 0.0, count: numberOfItems), count: numberOfItems)
var myArray2 = [[Double]](repeating: [Double](repeating: 0.0, count: numberOfItems), count: numberOfItems)
var myArray3 = [Double](repeating: 0.0, count: numberOfItems * numberOfItems)
var myArray4 = [Double](repeating: 0.0, count: numberOfItems * numberOfItems)
// 2D array assignment
let start1 = CFAbsoluteTimeGetCurrent()
var x = 0.0
for i in 0..<numberOfItems {
for j in 0..<numberOfItems {
myArray1[i][j] = x
x += 1
}
}
let diff1 = CFAbsoluteTimeGetCurrent() - start1
print(diff1 * 1000)
// 2D array access and assignment
let start2 = CFAbsoluteTimeGetCurrent()
for i in 0..<numberOfItems {
for j in 0..<numberOfItems {
myArray2[i][j] = myArray1[i][j]
}
}
let diff2 = CFAbsoluteTimeGetCurrent() - start2
print(diff2 * 1000)
// 1D array assignment
var y = 0.0
let start3 = CFAbsoluteTimeGetCurrent()
for i in 0..<(numberOfItems * numberOfItems) {
myArray3[i] = y
y += 1
}
let diff3 = CFAbsoluteTimeGetCurrent() - start3
print(diff3 * 1000)
// 1D array access and assignment
let start4 = CFAbsoluteTimeGetCurrent()
for i in 0..<(numberOfItems * numberOfItems) {
myArray4[i] = myArray3[i]
}
let diff4 = CFAbsoluteTimeGetCurrent() - start4
print(diff4 * 1000)
我 运行 它在命令行上使用 -Ounchecked 选项。我得到以下输出(以毫秒为单位,有些变化但通常非常接近):
6.0759782791137695
24.2689847946167
2.4139881134033203
1.5819072723388672
显然,二维和一维数组实现之间存在相当大的性能差异,尤其是在访问和分配时。
有没有办法在 Swift 中创建更高效的二维数组?在这种情况下,性能对我来说很重要,所以使用一维数组并为索引做一些数学运算会更好吗?
如果你真的想坚持使用二维数组,那么你可以使用不安全的缓冲区指针来加快访问速度。然而,一维数组仍然会更有效率。试一试。
// 2D array assignment
myArray1.withUnsafeMutableBufferPointer { outer1 -> Void in
for i in 0..<numberOfItems {
outer1[i].withUnsafeMutableBufferPointer { inner1 -> Void in
for j in 0..<numberOfItems {
inner1[j] = x
x += 1
}
}
}
}
// 2D array access and assignment
myArray1.withUnsafeMutableBufferPointer { outer1 -> Void in
myArray2.withUnsafeMutableBufferPointer { outer2 -> Void in
for i in 0..<numberOfItems {
outer1[i].withUnsafeMutableBufferPointer { inner1 -> Void in
outer2[i].withUnsafeMutableBufferPointer { inner2 -> Void in
for j in 0..<numberOfItems {
inner2[j] = inner1[j]
}
}
}
}
}
}