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
添加回答
举报