Go指针是存储变量内存地址的变量,通过&取地址、*解引用实现对原数据的访问与修改;用于函数内修改原值、避免大对象拷贝、构建链表等复杂结构,并因禁止指针运算和自动GC而更安全。

Go语言中的指针,本质上是一个变量,它存储的是另一个变量在内存中的地址。你可以把它想象成一张写着房间号的纸条,这张纸条(指针)本身不是房间(变量),但它能告诉你房间在哪里。
指针的核心操作:取地址与解引用
理解指针,关键在于掌握两个符号:& 和 *。
- & (取地址符):放在一个变量前面,可以获取这个变量在内存中的具体位置。例如,&a 就表示“变量 a 的地址是多少”。
- * (解引用符):放在一个指针变量前面,可以访问或修改这个指针所指向的内存地址里存储的实际值。例如,如果 p 是一个指向变量 a 的指针,那么 *p 就等同于 a 本身。
这两个操作是互补的。通过 &a 得到地址,赋值给指针 p;再通过 *p 就能读写 a 的值。这就是指针工作的基本循环。
为什么需要指针?实际用途解析
在Go中,函数传递参数时,默认是“值传递”,意味着会创建一份数据的完整拷贝。当处理大型结构体或数组时,这会消耗大量内存和CPU资源。指针提供了一个高效的解决方案。
立即学习“go语言免费学习笔记(深入)”;
- 实现函数内修改原数据:将变量的地址(指针)传入函数,函数内部拿到的是地址,通过解引用 * 直接操作该地址上的原始数据,从而改变了外部变量的值。
- 避免大对象拷贝:传递一个8字节的指针远比传递一个几百字节的结构体副本要快得多,性能提升显著。
- 构建复杂数据结构:像链表、树这样的数据结构,其节点之间就是靠指针链接起来的,一个节点的指针字段指向下一个节点的地址。
Go指针的安全性与底层原理
Go的指针设计得比C/C++更安全,这也是其底层原理的重要体现。
- 无指针运算:你不能对Go的指针进行加减操作(如 p++)。这从根本上杜绝了因错误计算地址而访问非法内存的风险,避免了野指针和内存越界等问题。
- 自动垃圾回收 (GC):程序员无需手动释放指针指向的内存。当一段内存不再被任何指针引用时,Go的GC会自动将其回收,防止了内存泄漏。
- 栈帧与内存布局:每个函数执行时都有自己的栈帧(Stack Frame),用于存放局部变量和参数。当你在一个函数里声明一个变量并取它的地址时,编译器会确保这个变量的生命周期足够长(可能分配在堆上),以便指针能够安全地指向它。指针变量本身也存储在某个栈帧中,它保存的数值就是一个内存地址。
基本上就这些。Go指针是高效操作内存的工具,它简单、直接,又因为语言层面的约束而非常安全。










