package main
import "fmt"
func main() {
a := [...]int{0, 1, 2, 3}
x := a[:1]
y := a[2:]
x = append(x, y...)
x = append(x, y...)
fmt.Println(a, x)
}
Choices:
Answer: [0 2 3 3] [0 2 3 3 3]
Run it on Go play.
Key points:
y
is [2 3]
,
and the slice x
is [0]
with three free element slots (in other words, its capacity is 4),
append
call changes the slice x
to [0 2 3]
with one free element slot.
And as the slice x
and the array a
share elements (before line 10),
the array a
is changed to [0 2 3 3]
.
The slice y
and the array a
also share elements,
so the slice y
is changed to [3 3]
.
x
has not enough free capacity,
the 2nd append
call allocates a new backing array for the slice x
.
So the call doesn't modify the array a
.
The slice x
is changed to [0 2 3 3 3]
.
The Go 101 프로젝트는 Github 에서 호스팅됩니다. 오타, 문법 오류, 부정확한 표현, 설명 결함, 코드 버그, 끊어진 링크와 같은 모든 종류의 실수에 대한 수정 사항을 제출하여 Go 101을 개선을 돕는 것은 언제나 환영합니다.
주기적으로 Go에 대한 깊이 있는 정보를 얻고 싶다면 Go 101의 공식 트위터 계정인 @go100and1을 팔로우하거나 Go 101 슬랙 채널에j가입해주세요.