這種構(gòu)建方法可以應(yīng)用于數(shù)組和切片:
for ix, value := range slice1 {
...
}
第一個(gè)返回值 ix 是數(shù)組或者切片的索引,第二個(gè)是在該索引位置的值;他們都是僅在 for 循環(huán)內(nèi)部可見的局部變量。value 只是 slice1 某個(gè)索引位置的值的一個(gè)拷貝,不能用來修改 slice1 該索引位置的值。
示例 7.9 slices_forrange.go
package main
import "fmt"
func main() {
var slice1 []int = make([]int, 4)
slice1[0] = 1
slice1[1] = 2
slice1[2] = 3
slice1[3] = 4
for ix, value := range slice1 {
fmt.Printf("Slice at %d is: %d\n", ix, value)
}
}
示例 7.10 slices_forrange2.go
package main
import "fmt"
func main() {
seasons := []string{"Spring", "Summer", "Autumn", "Winter"}
for ix, season := range seasons {
fmt.Printf("Season %d is: %s\n", ix, season)
}
var season string
for _, season = range seasons {
fmt.Printf("%s\n", season)
}
}
slicesforrange2.go 給出了一個(gè)關(guān)于字符串的例子, `` 可以用于忽略索引。
如果你只需要索引,你可以忽略第二個(gè)變量,例如:
for ix := range seasons {
fmt.Printf("%d", ix)
}
// Output: 0 1 2 3
如果你需要修改 seasons[ix]
的值可以使用這個(gè)版本。
多維切片下的 for-range:
通過計(jì)算行數(shù)和矩陣值可以很方便的寫出如(參考第 7.1.3 節(jié))的 for 循環(huán)來,例如(參考第 7.5 節(jié)的例子 multidim_array.go):
for row := range screen {
for column := range screen[row] {
screen[row][column] = 1
}
}
問題 7.5 假設(shè)我們有如下數(shù)組:items := [...]int{10, 20, 30, 40, 50}
a) 如果我們寫了如下的 for 循環(huán),那么執(zhí)行完 for 循環(huán)后的 items
的值是多少?如果你不確定的話可以測(cè)試一下:)
for _, item := range items {
item *= 2
}
b) 如果 a) 無法正常工作,寫一個(gè) for 循環(huán)讓值可以 double。
問題 7.6 通過使用省略號(hào)操作符 ...
來實(shí)現(xiàn)累加方法。
練習(xí) 7.7 sum_array.go
a) 寫一個(gè) Sum 函數(shù),傳入?yún)?shù)為一個(gè) 32 位 float 數(shù)組成的數(shù)組 arrF,返回該數(shù)組的所有數(shù)字和。
如果把數(shù)組修改為切片的話代碼要做怎樣的修改?如果用切片形式方法實(shí)現(xiàn)不同長(zhǎng)度數(shù)組的的和呢?
b) 寫一個(gè) SumAndAverage 方法,返回兩個(gè) int 和 float32 類型的未命名變量的和與平均值。
練習(xí) 7.8 min_max.go
寫一個(gè) minSlice 方法,傳入一個(gè) int 的切片并且返回最小值,再寫一個(gè) maxSlice 方法返回最大值。