3 回答

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

TA貢獻1848條經驗 獲得超6個贊
在 Go 中,您不能引用文字值(正式稱為 r 值)。請嘗試以下操作:
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"])
}
看看這個教程。

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