1.数组
//GO语言数组调用是值传递,不是引用传递,java是引用传递(即把管理权也给了),要小心
//数组调用传递
//GO语言数组调用是值传递,不是引用传递,java是引用传递(即把管理权也给了),要小心
lbd3 := [4]int{1, 2, 3, 4}
lbd4 := lbd3 //只是把值拷贝一份给你,我们管理的依旧是两个不同的数组,你对你的元素 *** 作不影响我
lbd4[0] = 100
fmt.Printf("lbd3=%d\n", lbd3[0]) //lbd3[0]的值并没有改变
fmt.Printf("lbd4=%d\n", lbd4[0])
aa(lbd3)
fmt.Printf("值是%d", lbd3[0]) //lbd3数组里的值并没有因为传入函数而改变,这叫值传递,如果是java,那就会变了哦
运行结果如下:
lbd3=[1 2 3 4]
lbd4=[100 2 3 4]
很明显,lbd4[0]号元素的改变并没有引起lbd3[0]号元素的改变。
虽然切片是动态数组,但在引用方面是不同的:
2.切片
//切片是引用传递,和数组不一样,切片把管理权也给了,即一起管理同一个数组
//切片是引用传递,和数组不一样,切片把管理权也给了,即一起管理同一个数组
d := make([]int, 3) //空切片[0,0,0]
fmt.Println(d)
e := d //e与d共用一个底层数组,e的值变了,d也跟着变
e[0] = 100
fmt.Println(d[0]) //对e修改值,d切片的值也一起变
fmt.Println(e[0])
结果如下:
[0 0 0]
100
100
3.但切片中的copy()函数却是值传递
//3.切片的copy()
var b []string
b = append(b, "北京", "海南", "世界") //b之前是nil,必须初始化才能用
fmt.Println(b, cap(b))
//也可以这样
c := []string{"河南", "杭州"}
b = append(b, c...) //注意加三个点哦,把c切片中的元素追加到b中
var e = make([]string, 5, 5)
copy(e, b) //copy()函数是值传递,e,b虽然值相同,但管理的是两个不同地址的数组,与e:=b不同
fmt.Println(b, e)
[北京 海南 世界] 3
[北京 海南 世界 河南 杭州] 6
[北京 海南 世界 河南 杭州] [北京 海南 世界 河南 杭州]
好温柔的风,吹到我心里去了
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)