¿Por qué prohibe tomar la dirección del miembro del mapa (&) y, sin embargo, permite el elemento de división (&)?
Ir no permite tomar la dirección de un miembro del mapa:
// if I do this:
p := &mm["abc"]
// Syntax Error - cannot take the address of mm["abc"]
La razón es que si Go permite tomar esta dirección, cuando el almacén de mapas crece o parpadea, la dirección puede volverse inválida, confundiendo al usuario.
Pero Go slice se reubica cuando supera su capacidad, sin embargo, Go nos permite tomar la dirección de un elemento de segmento:
a := make([]Test, 5)
a[0] = Test{1, "dsfds"}
a[1] = Test{2, "sdfd"}
a[2] = Test{3, "dsf"}
addr1 := reflect.ValueOf(&a[2]).Pointer()
fmt.Println("Address of a[2]: ", addr1)
a = append(a, Test{4, "ssdf"})
addrx := reflect.ValueOf(&a[2]).Pointer()
fmt.Println("Address of a[2] After Append:", addrx)
// Note after append, the first address is invalid
Address of a[2]: 833358258224
Address of a[2] After Append: 833358266416
¿Por qué está diseñado Go así? ¿Qué tiene de especial tomar la dirección del elemento de corte?