如何使用Golang理解指针和值类型函数区别_明确数据修改范围

9次阅读

指针参数能修改原始数据,值参数只能修改副本;Go 函数默认值传递,传指针可透过解引用直接修改原值,结构体传指针更高效且支持修改,但只读场景传值更安全。

如何使用 Golang 理解指针和值类型函数区别_明确数据修改范围

指针参数能修改原始数据,值参数只能修改副本

Go 语言中函数传参默认是“值传递”,也就是说,传进去的是变量的拷贝。对值类型(如 intstringstruct)来说,函数内修改参数不会影响调用方的原始变量。

而如果传入的是指针(比如 *int),函数拿到的是原始变量的内存地址,通过解引用(*p)就能直接读写原值,修改会反映到调用方。

结构体传值 vs 传指针:性能和可变性都要考虑

结构体较大时,传值会产生明显内存开销;传指针更轻量,且天然支持修改字段。但要注意:不是所有场景都需要可变性——如果函数只是读取结构体信息(比如计算面积、生成描述),传值更安全,避免意外修改。

  • 传值:适合小结构体、只读操作、强调不可变语义
  • 传指针:适合大结构体、需要修改字段、实现方法接收者(如 func (s *Student) SetName(n string)

切片、map、channel 是引用类型,但传参仍是值传递

它们底层包含指针字段(如 slice 有指向底层数组的指针),所以函数内可以修改元素内容(s[0] = 10),但不能改变其长度、容量或底层数组本身——除非传指针(*[]int)。例如:

立即学习go 语言免费学习笔记(深入)”;

  • append(s, x) 返回新切片,原变量不变,需显式赋值
  • 想在函数里扩容并让调用方看到变化,得传 *[]int 并在函数内重新赋值:*s = append(*s, x)

用具体例子对比看效果

下面两个函数处理同一个整数:

func modifyByValue(x int) {x = 42} func modifyByPtr(p *int)   {*p = 42}  a := 10 modifyByValue(a) fmt.Println(a) // 输出 10  modifyByPtr(&a) fmt.Println(a) // 输出 42

关键 区别 就在 &a*p:取地址传进去,再解引用改值。没有这两步,就只是在玩副本。

以上就是如何使用 Golang 理解指针和值类型函数

text=ZqhQzanResources