¿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?

Respuestas a la pregunta(2)

Su respuesta a la pregunta