在go语言,切片扩容会重新申请一块新的更大内存,将媛有切片的数据复制到这块新的内存中,而原始那一块空间,自然就释放掉了。
因此,如果当切片发生扩容时,如果指向原始切片底层数组的指针或索引没有及时更新到新的底层数组,就会出现越界访问问题。
理解:本来指针指向A区域,扩容操作,使得重新申请一块更大的B区域,然后让指针指向B,再释放掉A,如果指针还指向A区域,扩容后这块区域就是未分配的空间了,指向未分配空间,自然是越界了
在go语言,切片扩容会重新申请一块新的更大内存,将媛有切片的数据复制到这块新的内存中,而原始那一块空间,自然就释放掉了。
因此,如果当切片发生扩容时,如果指向原始切片底层数组的指针或索引没有及时更新到新的底层数组,就会出现越界访问问题。
理解:本来指针指向A区域,扩容操作,使得重新申请一块更大的B区域,然后让指针指向B,再释放掉A,如果指针还指向A区域,扩容后这块区域就是未分配的空间了,指向未分配空间,自然是越界了