```
import "fmt"
func main() {
intSlice := []int{1, 2, 3, 4}
for index, value := range intSlice {
fmt.Println(index, value)
// 情况1
//if value == 2 {
// intSlice = append(intSlice[:index], intSlice[index+1:]...)
//}
// 情况2
//intSlice = []int{}
}
}
```
这个例子很有趣,我没分析出原因。
range复制了切片,len和cap已经被复制,从而循环次数确定了,而指针通过下标在修改值时,就是在操作底层数组了。可以一边通过下标修改值,一边打印value来查看。
#8
更多评论
熟悉 slice 类型的内存布局就可以解释这两种情况了。slice 是由底层数组指针、len、cap 构成
情况一:
底层数组指针不变,所以append 操作还是原数组地址数据,在append 操作结束后,数组实际存储为 1,3,4,4
情况二:
range 关键字是会进行复制对象的,而 slice 是拷贝传递,所以在 for 中修改 intSlice 并不影响原来的 slice 迭代
#2