Por que a proibição de usar o endereço do membro (&) do mapa, ainda permite (&) o elemento de fatia?

Go não permite pegar o endereço de um membro do mapa:

// if I do this:
p := &mm["abc"]
// Syntax Error - cannot take the address of mm["abc"]

A lógica é que, se o Go permitir pegar esse endereço, quando o backstore do mapa cresce ou pisca, o endereço pode se tornar inválido, confundindo o usuário.

Mas a fatia Go é realocada quando ela excede sua capacidade; no entanto, a Go nos permite pegar o endereço de um elemento de fatia:

 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 que o Go foi projetado assim? O que há de especial em obter o endereço do elemento de fatia?

questionAnswers(2)

yourAnswerToTheQuestion