Comment exprimeriez-vous une boucle indexée décrémentante en Swift 3.0, où la syntaxe ci-dessous n'est plus valide?
for var index = 10 ; index > 0; index-=1{
print(index)
}
// 10 9 8 7 6 5 4 3 2 1
Voici une approche plus facile (et plus Swifty).
for i in (0 ..< 5).reversed() {
print(i) // 4,3,2,1,0
}
let array = ["a", "b", "c", "d", "e"]
for element in array.reversed() {
print(element) // e,d,c,b,a
}
array.reversed().forEach { print($0) } // e,d,c,b,a
print(Array(array.reversed())) // e,d,c,b,a
Les boucles de style C avec un incrément ou une décrémentation fixe peuvent être remplacées par stride()
:
for index in 10.stride(to: 0, by: -1) {
print(index)
}
// 10 9 8 7 6 5 4 3 2 1
Utilisez stride(to: ...)
ou stride(through: ...)
selon que le dernier élément doit être inclus ou non.
C'est pour Swift 2. La syntaxe a changé (encore) pour Swift 3, voir cette réponse .
Depuis Swift 3.0
, La méthode stride(to:by:)
sur Strideable a été remplacée par une fonction libre, stride(from:to:by:)
for index in stride(from: 10, to: 0, by: -1){
print(index)
}
Vous pouvez utiliser la méthode stride
:
10.stride(through: 0, by: -1).forEach { print($0) }
ou boucle classique.
Si vous souhaitez toujours utiliser cette boucle de style C, voici ce dont vous avez besoin:
let x = 10
infix operator ..> { associativity left }
func ..>(left: Int, right: Int) -> StrideTo<Int> {
return stride(from: left, to: right, by: -1)
}
for i in x..>0 {
print(i)
}