Go で構造体の参照を解除すると新しいコピーが作成されますか?
Go では、構造体型の変数が参照によって渡されるときに、アスタリスク (*) 演算子を使用すると、逆参照された変数が元の変数と同じアドレスを表すという誤解が生じる可能性があります。 struct.
ただし、指定されたコード スニペットに示すように:
package main import ( "fmt" ) type me struct { color string total int } func study() *me { p := me{} p.color = "tomato" fmt.Printf("%p\n", &p.color) // Address of p.color return &p } func main() { p := study() // p is a pointer to a struct fmt.Printf("&p.color = %p\n", &p.color) // Address of p.color obj := *p // obj is a copy of the struct pointed to by p fmt.Printf("&obj.color = %p\n", &obj.color) // Address of obj.color fmt.Printf("obj = %+v\n", obj) p.color = "purple" // Changes color of the struct pointed by p fmt.Printf("p.color = %p\n", &p.color) fmt.Printf("p = %+v\n", p) fmt.Printf("obj = %+v\n", obj) obj2 := *p // Another copy is made fmt.Printf("obj2 = %+v\n", obj2) }
このコードを実行すると、逆参照された変数 obj のアドレスが元の構造体 p とは異なることが出力に表示されます。 。これは、
逆参照により新しいコピーが作成されるためです。
行 obj := *p は、p (me) と同じ型の新しい変数 obj を作成します。そして、p が指す値のコピーでそれを初期化します。これは、obj に加えられた変更は元の構造体には影響しないことを意味します。
新しい構造体の値を別の構造体に効果的に代入する:
var obj me = *p と同様、 obj := *p の逆参照操作は、新しい構造体の値を変数 obj に割り当てます。これにより、別のメモリを持つ新しいコピーが作成されます。
アスタリスク演算子の使用には注意してください:
アスタリスク演算子はポインター セマンティクスを提供しますが、変数に対するその影響を理解することが重要です。 。 * (逆参照) 演算子を使用して値が割り当てられると、元の変数への新しい参照ではなく、新しいコピーが作成されます。
以上がGo 構造体を逆参照すると新しいコピーが作成されますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。