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?