
Go语言中指针和指针的指针:关键区别
Go语言允许指针指向变量的内存地址。然而,在函数内部操作指针时,理解指针和指针的指针之间的差异至关重要。
示例中,我们在函数外部声明了一个整型变量 i,并使用取地址符 & 获取其内存地址。输出结果如预期,显示了 i 的内存地址(例如:0x16b178)。
但当我们将指针变量 ip 传递给函数 zeroptr 后,情况有所不同。函数内部打印的地址变成了 0x16a038。
立即学习“go语言免费学习笔记(深入)”;
这是因为指针的层次不同。ip 是一个指针,指向变量 i 的地址。在 zeroptr 函数内部,&ip 获取的是指针 ip 本身的内存地址,而不是 ip 指向的变量 i 的地址。因此,输出的是 ip 的地址(0x16a038),而不是 i 的地址(0x16b178)。
简而言之,函数外部打印的是变量的内存地址,而函数内部打印的是指针变量的内存地址。理解这种区别对于熟练掌握Go语言的指针操作至关重要。










