如何在Golang中理解指针与内存分配

指针存储变量地址,通过&取地址、*解引用;new分配零值内存返回指针,make初始化slice、map、channel;指针接收者可修改原对象;逃逸分析决定变量或堆分配。

如何在golang中理解指针与内存分配

在Golang中,指针和内存分配是理解程序如何管理数据的基础。掌握它们有助于写出更高效、更安全的代码。

指针的基本概念

指针是一个变量,它存储另一个变量的内存地址。使用&操作符可以获取变量的地址,而*操作符用于访问指针所指向的值。

例如:

a := 10
p := &a // p 是指向 a 的指针
fmt.Println(p) // 输出类似 0xc00001a078(a 的地址)
fmt.Println(*p) // 输出 10(p 指向的值)

修改指针指向的值会影响原始变量:

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

*p = 20
fmt.Println(a) // 输出 20

new 和 make 的区别

Golang 提供了两种主要方式来分配内存:newmake,但它们用途不同。

new(T) 为类型 T 分配零值内存,并返回指向它的指针 *T。适用于基本类型或结构体。 make(T) 用于 slice、map 和 channel,初始化它们的内部结构并返回可用的值,而不是指针。

示例:

ptr := new(int) // 分配一个 int,初始值为 0
*ptr = 5 // 赋值
fmt.Println(*ptr) // 输出 5

m := make(map[string]int) // 初始化 map,可直接使用
m[“age”] = 30

注意:不能对未初始化的 map 使用 new,否则会 panic。

结构体与指针接收者

在方法定义中,使用指针接收者可以让方法修改调用者本身。

比如:

type Person struct {
  Name string
}

func (p Person) Rename(n string) {
  p.Name = n // 只修改副本
}

func (p *Person) RenamePtr(n string) {
  p.Name = n // 修改原对象
}

调用时:

person := Person{Name: “Alice”}
person.Rename(“Bob”)
fmt.Println(person.Name) // 仍是 Alice

person.RenamePtr(“Bob”)
fmt.Println(person.Name) // 变成 Bob

逃逸分析与栈堆分配

Go 编译器通过逃逸分析决定变量是分配在栈上还是堆上。大多数局部变量分配在栈上,生命周期短;如果变量被外部引用(如返回局部变量指针),则会被分配到堆上。

开发者通常不需要手动干预,但了解这一点有助于避免不必要的内存开销。

可以通过编译命令查看逃逸分析结果:

go build -gcflags=”-m” your_file.go

输出信息会提示哪些变量逃逸到了堆。

基本上就这些。指针不是魔法,而是对内存的直接引用。合理使用 new、make 和指针接收者,能让你更好地控制数据的生命周期和性能表现。不复杂但容易忽略细节。

以上就是如何在Golang中理解指针与内存分配的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1417738.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月16日 11:39:05
下一篇 2025年12月16日 11:39:22

相关推荐

发表回复

登录后才能评论
关注微信