3 回答

TA貢獻(xiàn)1883條經(jīng)驗(yàn) 獲得超3個(gè)贊
指針是內(nèi)存地址。例如,一個(gè)變量在內(nèi)存中有一個(gè)地址。
類似操作的結(jié)果3 + 4沒(méi)有地址,因?yàn)闆](méi)有為其分配特定的內(nèi)存。結(jié)果可能只存在于處理器寄存器中。
您必須分配內(nèi)存,其地址可以放入映射中。最簡(jiǎn)單和最直接的方法是為它創(chuàng)建一個(gè)局部變量。
看這個(gè)例子:
x, y := 1, 2
m := map[string]*int{"x": &x, "y": &y}
d := *m["x"] + *m["y"]
m["d"] = &d
fmt.Println(m["d"], *m["d"])
輸出(在Go Playground上試試):
0x10438300 3
注意:如果上面的代碼是一個(gè)函數(shù),局部變量(地址d,我們剛剛投入地圖)將繼續(xù)即使我們從功能(即如果返回居住map退回或創(chuàng)建之外-如全局變量)。在 Go 中,獲取并返回局部變量的地址是完全安全的。編譯器將分析代碼,如果地址(指針)轉(zhuǎn)義函數(shù),它將自動(dòng)在堆上(而不是在堆棧上)分配。有關(guān)詳細(xì)信息,請(qǐng)參閱常見(jiàn)問(wèn)題解答:如何知道變量是分配在堆上還是堆棧上?
注意#2:還有其他方法可以創(chuàng)建指向值的指針(如本答案所述:How do I do a literal *int64 in Go?),但它們只是“技巧”,并沒(méi)有更好或更高效。使用局部變量是最干凈和推薦的方法。
例如,這也可以在不創(chuàng)建局部變量的情況下工作,但顯然根本不直觀:
m["d"] = &[]int{*m["x"] + *m["y"]}[0]
輸出是一樣的。在Go Playground上試試。

TA貢獻(xiàn)1848條經(jīng)驗(yàn) 獲得超6個(gè)贊
在 Go 中,您不能引用文字值(正式稱為 r 值)。請(qǐng)嘗試以下操作:
package main
import "fmt"
func main() {
x := 3;
y := 2;
m := make(map[string]*int)
m["x"] = &x
m["y"] = &y
f := *m["x"] + *m["y"]
m["d"] = &f
fmt.Printf("Result: %d\n",*m["d"])
}
看看這個(gè)教程。

TA貢獻(xiàn)1809條經(jīng)驗(yàn) 獲得超8個(gè)贊
加法的結(jié)果被放置在某個(gè)臨時(shí)的地方(在堆棧上),因此取其地址是不安全的。您應(yīng)該能夠通過(guò)int在堆上顯式分配一個(gè)來(lái)保存您的結(jié)果來(lái)解決這個(gè)問(wèn)題:
result := make(int)
*result = *m["x"] + *m["y"]
m["d"] = result
添加回答
舉報(bào)