Şöyle bir şey söyleyebilmek uygun olacaktır:
for _, element := reverse range mySlice {
...
}
Yanıtlar:
Yerinde bir aralığa eklemek için bunun için uygun bir operatör yoktur. Geri sayım için normal bir for döngüsü yapmanız gerekecek:
s := []int{5, 4, 3, 2, 1}
for i := len(s)-1; i >= 0; i-- {
fmt.Println(s[i])
}
Ayrıca şunları da yapabilirsiniz:
s := []int{5, 4, 3, 2, 1}
for i := range s {
fmt.Println(s[len(s)-1-i]) // Suggestion: do `last := len(s)-1` before the loop
}
Çıktı:
1
2
3
4
5
Ayrıca burada: http://play.golang.org/p/l7Z69TV7Vl
Endeksli varyasyon
for k := range s {
k = len(s) - 1 - k
// now k starts from the end
}
Ertelemeye ne dersiniz:
s := []int{5, 4, 3, 2, 1}
for i, _ := range s {
defer fmt.Println(s[i])
}
defer
ancak bunu bir döngü içinde tersine çevirmek için kullanmanın oldukça zor olduğuna ve hafıza açısından oldukça etkisiz olması gerektiğine inanıyorum.
defer
amaçlanmayan bir şekilde kullanılıyor . Kötü yan etkileri olabileceğinden bunu kullanmayın (sıra dışı uygulama). Sadece for
kabul edilen cevapta döngüyü kullanın . Go, daha sonra sizi kıçınıza sokma eğiliminde olduklarından , bu tür zekice (değil) saldırıları en aza indirmeyi amaçlamaktadır .
Bir işlevdeki bir listeyi çoğaltmadan ters çevirmek için bir kanal kullanılabilir. Bence kodu daha güzel yapıyor.
package main
import (
"fmt"
)
func reverse(lst []string) chan string {
ret := make(chan string)
go func() {
for i, _ := range lst {
ret <- lst[len(lst)-1-i]
}
close(ret)
}()
return ret
}
func main() {
elms := []string{"a", "b", "c", "d"}
for e := range reverse(elms) {
fmt.Println(e)
}
}
[]interface{}
? Çünkü şimdiki reverse
işlevi yalnızca dizeleri destekler.
func reverse(lst []interface{}) chan inyterface{}
artık girdi olarak bir [] dizesi almayacağını vurgulamak istiyorum . {} Arayüzünde dizge dönüştürülebilir olsa bile, [] dizesi [] arabirim {} içinde dönüştürülemez. Ne yazık ki, şimdiki ters işlev, çok fazla yeniden yazılması gereken işlev türüdür.
Bir dilimden ve ters aralıktan öğeler çıkarmam gerektiğinde, şu kod gibi bir şey kullanıyorum:
// reverse range
// Go Playground: https://play.golang.org/p/gx6fJIfb7fo
package main
import (
"fmt"
)
type Elem struct {
Id int64
Name string
}
type Elems []Elem
func main() {
mySlice := Elems{{Id: 0, Name: "Alice"}, {Id: 1, Name: "Bob"}, {Id: 2, Name: "Carol"}}
for i, element := range mySlice {
fmt.Printf("Normal range: [%v] %+v\n", i, element)
}
//mySlice = Elems{}
//mySlice = Elems{{Id: 0, Name: "Alice"}}
if last := len(mySlice) - 1; last >= 0 {
for i, element := last, mySlice[0]; i >= 0; i-- {
element = mySlice[i]
fmt.Printf("Reverse range: [%v] %+v\n", i, element)
}
} else {
fmt.Println("mySlice empty")
}
}
Çıktı:
Normal range: [0] {Id:0 Name:Alice}
Normal range: [1] {Id:1 Name:Bob}
Normal range: [2] {Id:2 Name:Carol}
Reverse range: [2] {Id:2 Name:Carol}
Reverse range: [1] {Id:1 Name:Bob}
Reverse range: [0] {Id:0 Name:Alice}
Oyun alanı: https://play.golang.org/p/gx6fJIfb7fo