go切片做了reslice操作,底层数组被切片出去的部分会被垃圾回收吗?

wubbalubbaaa · · 1315 次点击
```go package main import ( "fmt" _ "net/http/pprof" "runtime" ) type pslice *[]int func makeArr() []pslice { arr := make([]pslice, 800000) return arr } func printMem() { var rtm runtime.MemStats runtime.ReadMemStats(&rtm) fmt.Printf("%f MB\n", float64(rtm.Alloc)/1024./1024.) } func main() { arr := makeArr() for i := 0; i < len(arr); i++ { slice := make([]int, 100) arr[i] = &slice } arr = arr[:5] printMem() //716.924133 MB runtime.GC() fmt.Println(len(arr))//注意这行 printMem() //8.912193 MB } ``` 结果: ``` 708.285545 MB 5 708.290962 MB ```
#5
更多评论
slice是 []pslice 底层数组是[n]pslice 和里面装的什么东西没关系。
#1
谢谢回复, 但是我没太看懂你说的呢? 我想知道一个切片做了reslice操作, 如arr=arr[:1]之后, 底层数组多出的部分会被垃圾回收吗? 我觉得理论上不应该垃圾回收, 但是上面代码, 我在堆上面分配了一个长度为800000的切片, 在此切片基础上切片, 之后调用printMem打印当前内存分配 在垃圾回收前后明显内存降低了啊, 这不是被回收了吗?比较疑惑
#2