Closed wtysos11 closed 3 years ago
最近在快速阅读《go语言高级编程》,里面提到Go语言的栈会自动调整大小,所以go程序员是难以关心栈的运行机制。比如说,程序员很难知道局部变量到底是保存在栈中还是保存在堆中
可以使用下面的代码来作为例子:
package main import "fmt" func f(x int) *int{ return &x } func main(){ s := 5 t := f(s) s += 1 fmt.Println(s,*t) }
上述代码的输出结果是6,5。这个结果说明t所指向的局部变量确实是函数内部的(如果是指向参数的地址,则参数变化时它也应该跟着变化)。也就是说,这个函数的局部变量的地址在函数结束之后仍然存在。
6,5
PS:如果想要让该指针指向参数
package main import "fmt" func f(x *int) *int{ return x } func main(){ s := 5 t := f(&s) s += 1 fmt.Println(s,*t) }
书中的这一部分提到了两个观点:
最近在快速阅读《go语言高级编程》,里面提到Go语言的栈会自动调整大小,所以go程序员是难以关心栈的运行机制。比如说,程序员很难知道局部变量到底是保存在栈中还是保存在堆中
可以使用下面的代码来作为例子:
上述代码的输出结果是
6,5
。这个结果说明t所指向的局部变量确实是函数内部的(如果是指向参数的地址,则参数变化时它也应该跟着变化)。也就是说,这个函数的局部变量的地址在函数结束之后仍然存在。PS:如果想要让该指针指向参数
书中的这一部分提到了两个观点: