GO 语言的 for…range
能做什么呢?
for…range
如何应用 ?
for…range
的返回值有哪些状况,能够对于任何数据结构应用吗?
for…range
的返回值如果不须要,能够如何解决?
for…range
的数据是如何传递的?
刚学习 golang 的 xdm 会不会有下面的疑难?其实很简略,咱们就一个一个的来分享和实操一遍
GO 语言的 for…range
能做什么呢?
golang 的 for…range
是 go 本身的语法,能够用来遍历数据结构,有如下数据结构能够遍历
- 切片 slice
- 数组 array
- map 哈希表
- channel 通道
for…range
如何应用 ?
咱们别离来看看能够如何应用他们,for…range
相当于一个迭代器,能够遍历数据结构的键/索引 和值
数组 array
- 初始化一个数组
- 应用
for…range
遍历 , 对应的是 索引 和 值
func main() { myArray := [5]int{1, 2, 3, 4, 5} for i, v := range myArray { fmt.Printf("%d -- %d -- %p\n", i, v, &v) }}
切片 slice
- 初始化一个切片
- 应用
for…range
遍历 , 对应的是 索引 和 值
mySlice := []int{1, 2, 3, 4, 5} for i, v := range mySlice { fmt.Printf("%d -- %d -- %p\n", i, v, &v)}
map 哈希表
- 初始化一个 map 哈希表
- 应用
for…range
遍历 , map 对应的 键值对
myMap := map[string]string{ "name": "xmt", "hobby": "program", "addr": "mengli",}for k, v := range myMap { fmt.Printf("%s -- %s -- %p\n", k, v, &v)}
channel 通道
- 创立一个能够缓冲 10 个 int 类型数据的通道
- 创立一个协程专门向通道中写入数据
- 主协程遍历通道,读取数据
package mainimport "fmt"var myCh = make(chan int, 10)func writeCh() { for i := 0; i < 5; i++ { myCh <- i } close(myCh)}func main() { go writeCh() for { for data := range myCh { fmt.Println(data) } break }}
for…range
的返回值有哪些状况,能够对于任何数据结构应用吗?
并不是所有数据结构都能够应用 for…range
的,如下构造能够应用这个办法
返回值 1 | 返回值 2 | 数据传递 | |
---|---|---|---|
字符串 | 索引 | 索引对应的值 | 值传递 |
数组或者切片 | 索引 | 索引对应的值 | 数组:值传递 切片:援用传递 |
哈希表 | 键 | 键对应的值 | 指针 |
通道 | 通道中的数据 | 指针 |
for…range
的返回值如果不须要,能够如何解决?
置信写过 golang 的 xdm 都晓得,go 外面对于咱们不须要的返回值,都能够应用 -
来示意 ,因而 for…range
当然也能够这样
例如:
myMap := map[string]string{ "name": "xmt", "hobby": "program", "addr": "mengli",}for _, v := range myMap { fmt.Printf("%s -- %p\n", v, &v)}
for…range
的数据是如何传递的?
数据都是通过复制传递的,也就是都是值传递的,只不过因为数据结构不一样,数组和切片在这里还是有一些区别的
后面的文章,咱们有说到,切片,对应着 有 3 个元素的数据结构,一个是 cap,一个是 len, 一个是 ptr ,指向的是一个底层数组
切片是援用传递,然而传递数据的时候,切片这个变量是值传递,然而它理论指向的底层数组还是不会变的
咱们来写一个 demo 查看一下:
咱们思路是这个样子:
遍历一个 数组/切片,在遍历以后值的时候,去批改前面索引对应的值,全副遍历结束后,查看后果中,理论的数据是否会被批改掉,若批改掉了,则是切片是传援用,若没有批改掉,则是数组是传值
数组的成果
myArray := [5]int{1, 2, 3, 4, 5}fmt.Println(myArray)for i, v := range myArray { if i == 0{ myArray[2] = 888 } fmt.Printf("%d -- %d -- %p\n", i, v, &myArray[i])}
成果如下:
go run main.go[1 2 3 4 5]0 -- 1 -- 0x1189c1201 -- 2 -- 0x1189c1242 -- 3 -- 0x1189c1283 -- 4 -- 0x1189c12c4 -- 5 -- 0x1189c130
切片的成果
mySlice := []int{1, 2, 3, 4, 5}fmt.Println(mySlice)for i, v := range mySlice { if i == 0{ mySlice[2] = 888 } fmt.Printf("%d -- %d -- %p\n", i, v, &mySlice[i])}
成果如下:
go run main.go[1 2 3 4 5]0 -- 1 -- 0x1140e3401 -- 2 -- 0x1140e3442 -- 888 -- 0x1140e3483 -- 4 -- 0x1140e34c4 -- 5 -- 0x1140e350
通过上述的案例,置信心里都有点谱了吧
欢送点赞,关注,珍藏
敌人们,你的反对和激励,是我保持分享,提高质量的能源
好了,本次就到这里
技术是凋谢的,咱们的心态,更应是凋谢的。拥抱变动,背阴而生,致力向前行。
我是阿兵云原生,欢送点赞关注珍藏,下次见~