Go 中结构体内存分配:指针与结构体变量,有何区别?
求解 go 中的内存分配基础
在 go 语言中,内存管理是至关重要的。本文将探讨结构体的内存分配机制,以加深理解 go 的内存管理机制。
问题:结构体的内存分配
给定以下代码:
type test struct { a int b float64 } t := &test{a: 1, b: 2}
问题 1: t 在 memory 中存储的是结构体的地址吗?这个地址指向哪里?
回答 1: t 确实存储了结构体的地址,指向结构体中第一个元素的地址。可通过以下代码验证:
ap := (*int)(unsafe.Pointer(t)) bp := (*float64)(unsafe.Add(unsafe.Pointer(t), unsafe.Sizeof(t.a))) fmt.Println(*ap, *bp)
问题 2: t:=&test 和 t:=test 在内存分布上是否有区别?
回答 2: 是的,存在区别。t:=&test 创建一个指向结构体的指针,而 t:=test 创建一个结构体,分配在栈上。编译器会通过逃逸分析优化,决定将结构体分配在堆上还是栈上。
以上就是Go 中结构体内存分配:指针与结构体变量,有何区别?的详细内容,更多请关注其它相关文章!