如果我想枚举一个数组(例如用于 map()
函数,需要同时使用元素的索引和值),我可以使用 enumerate()
函数。例如:
import Foundation
let array: [Double] = [1, 2, 3, 4]
let powersArray = array.enumerate().map() {
pow($0.element, Double($0.index))
}
print("array == \(array)")
print("powersArray == \(powersArray)")
// array == [1.0, 2.0, 3.0, 4.0]
// powersArray == [1.0, 2.0, 9.0, 64.0] <- As expected
现在,如果我想要使用数组中的某些子序列,我可以使用slice
,它将允许我使用与原始数组相同的索引(这正是我在for
循环中使用subscript
访问器所需要的)。例如:
let range = 1..<(array.count - 1)
let slice = array[range]
var powersSlice = [Double]()
for index in slice.indices {
powersSlice.append(pow(slice[index], Double(index)))
}
print("powersSlice == \(powersSlice)")
// powersSlice == [2.0, 9.0] <- As expected
然而,如果我尝试像在原始数组中使用enumerate().map()
方法一样,那么我会得到完全不同的行为。我将不再是通过slice
的索引范围获取数据,而是得到一个新的基于0的索引范围:
let powersSliceEnumerate = slice.enumerate().map() {
pow($0.element, Double($0.index))
}
print("powersSliceEnumerate == \(powersSliceEnumerate)")
// powersSliceEnumerate == [1.0, 3.0] <- Not as expected
问题是是否有一种好的方式(即不使用偏移量或其他手动调整)来使用切片自己的索引而不是自动生成的基于0的索引来枚举切片?
let powersSlice = slice.indices.map { pow(slice[$0], Double($0)) }
替换 for 循环。 - Martin Renumerate
生成的索引范围更好的解决方法。 - 0x416e746f6e