当你把 a 变量赋值给 b 变量时,其实就是深和浅把 a 变量拷贝给 b 变量
a := "hello" b := a这只是拷贝最简单的一种形式,而有些形式却表现得非常的拷贝拷贝隐蔽。比如:
你往一个函数中传参 你向通道中传入对象这些其实在 Go编译器中都会进行拷贝的篇学动作。
知道了什么是拷贝,那我们再往深点开挖,拷贝拷贝聊聊深浅拷贝。篇学
不过先别急,深和浅咱先了解下数据结构的拷贝拷贝两种类型:
值类型 :String,Array,篇学Int,深和浅Struct,拷贝拷贝Float,篇学Bool
引用类型:Slice,深和浅Map
这两种不同的服务器托管拷贝拷贝类型在拷贝的时候,在拷贝的时候效果是完全不一样的,这对于很多新手可能是一个坑。
对于值类型来说,你的每一次拷贝,Go 都会新申请一块内存空间,来存储它的值,改变其中一个变量,并不会影响另一个变量。
func main() { aArr := [3]int{ 0,1,2} fmt.Printf("打印 aArr: %v \n", aArr) bArr := aArr aArr[0] = 88 fmt.Println("将 aArr 拷贝给 bArr 后,并修改 aArr[0] = 88") fmt.Printf("打印 aArr: %v \n", aArr) fmt.Printf("打印 bArr: %v \n", bArr) }从输出结果来看,aArr 和 bArr 相互独立,互不干扰
打印 aArr: [0 1 2] 将 aArr 拷贝给 bArr 后,并修改 aArr[0] = 88 打印 aArr: [88 1 2] 打印 bArr: [0 1 2]对于引用类型来说,你的每一次拷贝,云服务器Go 不会申请新的内存空间,而是使用它的指针,两个变量名其实都指向同一块内存空间,改变其中一个变量,会直接影响另一个变量。
func main() { aslice := []int{ 0,1,2} fmt.Printf("打印 aslice: %v \n", aslice) bslice := aslice aslice[0] = 88 fmt.Println("将 aslice 拷贝给 bslice 后,并修改 aslice[0] = 88") fmt.Printf("打印 aslice: %v \n", aslice) fmt.Printf("打印 bslice: %v \n", bslice) }从输出结果来看,aslice 的更新直接反映到了 bslice 的值。
打印 aslice: [0 1 2] 将 aslice 拷贝给 bslice 后,并修改 aslice[0] = 88 打印 aslice: [88 1 2] 打印 bslice: [88 1 2]是不是很简单?跟着明哥一起来攻克 Go 的各个边边角角的知识吧
加油噢,我们下篇见
本文转载自微信公众号「Go编程时光」,可以通过以下二维码关注。转载本文请联系Go编程时光公众号。