我想问大佬们的问题是:map在func中传参时的引用传递和指针传递有什么区别?
为什么切片通过函数修改前后的内存地址没有改变。而map的内存地址却改变了呢?
以下是代码:
```
func alter_map(a map[int]int){
a[1] = 2
f.Printf("%p\n", a)//查看修改【后】的map的内存地址
}
func main() {
a := make(map[int]int, 2)
a[2] =1
f.Printf("%p\n", &a) //查看修改【前】的map的内存地址
alter_map(a) //修改map
f.Println(a)
}
输出
0xc04206a018
0xc04207a060 //内存地址改变了
map[2:1 1:2] //证明是引用传递
```
给我一点参考资料也ok,最好不要是csdn的文章,看了太多,发现都是主观居多。
阿里嘎多!!!
老哥,看下我下面的理解对了没:
map创建的时候,字面值a(文中创建map的变量)其实本身就是对底层数据的一个引用,这个引用生成的无数个副本的指向也都是同一份底层数据(所以在函数中会让人产生引用传递的错觉);
而这里所谓的“引用”应该就是那个“标头值”,而标头值就是一楼老哥引用的文章原话“包含一个指向底层数据结构的指针”,我说的对吗???
#7
更多评论
golang 的参数传递都是值传递。
https://blog.tanteng.me/2017/11/golang-parameter-passing/
相信看完这篇文章能有一个更好的理解。
#1
感谢回答,文章中“标头”的概念不好理解啊,,如果都是值传递的话,那golang中的func的传参设计岂不是有很大的问题吗,调用一次函数都要在内存中拷贝一个副本 ?
#2