我寫了這個測試代碼:import "fmt"func getIntPointer(i int) *int { var result int result = i + 1 return &result}func main () { ip1 := getIntPointer(4) ip2 := getIntPointer(10) fmt.Println(*ip1, *ip2) fmt.Printf("%p %p\n", ip1, ip2)}我希望看到:1111address1address1假設(shè)第二次調(diào)用將為函數(shù)變量使用相同的空間(基于我的 C 背景,在函數(shù)停止工作后,所有放置在堆棧中的函數(shù)變量都可以用下一個函數(shù)調(diào)用重寫)。但相反,我得到了:511address1address2為什么我可能會得到這個結(jié)果?為什么與預(yù)期輸出有差異?
1 回答

慕妹3242003
TA貢獻(xiàn)1824條經(jīng)驗(yàn) 獲得超6個贊
這種行為是逃逸分析的結(jié)果。編譯器檢測到變量result轉(zhuǎn)義了函數(shù),所以它是在堆上分配的。這就是為什么每次調(diào)用都getIntPointer返回一個新result指針的原因。該函數(shù)等價(jià)于:
func getIntPointer(i int) *int {
result:=new(int)
*result=i+1
return result
}
- 1 回答
- 0 關(guān)注
- 95 瀏覽
添加回答
舉報(bào)
0/150
提交
取消