Go中值类型赋值、传参、返回时进行完整拷贝,修改副本不影响原值;小类型拷贝快,大结构体或含指针字段时需谨慎,string为浅拷贝;结构体超16–24字节或含sync.Mutex等不可拷贝类型时应优先用指针。

Go语言中,值类型的复制行为是理解程序内存模型和性能表现的关键。基本数据类型(如int、float64、bool、string)和结构体(struct)都属于值类型,它们在赋值、函数传参、返回值时会进行**完整拷贝**——不是共享引用,而是创建一份独立副本。
当一个值类型变量被赋值给另一个变量时,Go会在目标位置分配等大小的内存空间,并把原值的所有字节原样复制过去。这意味着:
int)极快;大结构体(如含大量字段或大数组的struct)可能带来明显性能损耗string虽是值类型,但底层由指针+长度+容量构成,拷贝时只复制这三个字段(24字节),不复制底层字节数组,所以是“浅拷贝”,但语义上仍不可变,表现安全结构体是否“大”直接影响你是否该考虑避免复制:
type Point struct{ X, Y int }):直接传值清晰、安全、无副作用,推荐[1024]int数组或多个大字段):每次调用函数都复制数百/数千字节,容易成为瓶颈map/slice/chan字段时:值拷贝只复制指针本身,底层数据仍被共享——这是“浅拷贝”,需特别注意并发读写或意外修改这不是非黑即白的选择,而要看设计意图和实际开销:
立即学习“go语言免费学习笔记(深入)”;
*T
sync.Mutex等不可拷贝类型 → 必须用指针(否则编译失败)用unsafe.Sizeof看类型大小,用fmt.Printf("%p", &v)打印地址,能快速确认是否发生拷贝:
type Big struct{ data [1000]int }
func f(v Big) { fmt.Printf("inside: %p\n", &v) } // 地址与调用方不同
func fp(v *Big) { fmt.Printf("inside: %p\n", v) } // 地址与调用方相同(解引用后)对比输出就能直观看到值传递 vs 指针传递的内存行为差异。
以上就是如何在Golang中理解值类型_基本数据类型和结构体复制行为的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号