golang释放map内存的方法:首先删除map中的所有key,map占用内存仍处于【使用状态】;然后map置为nil,map占用的内存处于【空闲状态】;最后处于空闲状态内存,一定时间内在下次申请的可重复被使用,不必再向操作系统申请即可。

golang释放map内存的方法:

示例代码:
go version: 1.12.9

package mainimport (    "log"    "runtime")var intMap map[int]intvar cnt = 8192func main() {    printMemStats()    initMap()    runtime.GC()    printMemStats()    log.Println(len(intMap))    for i := 0; i < cnt; i++ {        delete(intMap, i)    }    log.Println(len(intMap))    runtime.GC()    printMemStats()    intMap = nil    runtime.GC()    printMemStats()}func initMap() {    intMap = make(map[int]int, cnt)    for i := 0; i < cnt; i++ {        intMap[i] = i    }}func printMemStats() {    var m runtime.MemStats    runtime.ReadMemStats(&m)    log.Printf("Alloc = %v TotalAlloc = %v Sys = %v NumGC = %v\n", m.Alloc/1024, m.TotalAlloc/1024, m.Sys/1024, m.NumGC)}

输出结果:

2019/11/22 15:42:33 Alloc = 138 TotalAlloc = 138 Sys = 68290 NumGC = 02019/11/22 15:42:33 Alloc = 456 TotalAlloc = 460 Sys = 68610 NumGC = 12019/11/22 15:42:33 81922019/11/22 15:42:33 02019/11/22 15:42:33 Alloc = 458 TotalAlloc = 464 Sys = 68674 NumGC = 22019/11/22 15:42:33 Alloc = 146 TotalAlloc = 466 Sys = 68674 NumGC = 3

字段说明:

  • Alloc: 当前堆上对象占用的内存大小;

  • TotalAlloc:堆上总共分配出的内存大小;

  • Sys: 程序从操作系统总共申请的内存大小;

  • NumGC: 垃圾回收运行的次数。

从运行结果可以看出,map中的key被删除以后占用的内存并没有被释放掉。

结论:
golang的map在key被删除之后,并不会立即释放内存,所以随着程序的运行,实际上map占用的内存只会越来越大。此外,GC会在标记阶段访问map中的每一个元素,当map非常大时这会对程序性能带来非常大的开销。不过go 1.5版本之后,如果map的key和value中都不包含指针,那么GC会忽略这个map。

相关学习推荐:Go语言教程

更多相关文章

  1. 从XML中读取数据到内存的实例
  2. yarn-site.xml的部分资源配置参数,主要是与内存相关
  3. Redis 哈希结构内存模型剖析
  4. 5个小技巧彻底搞懂JVM内存模型【针对3年以上Java开发】
  5. 小心递归中内存泄漏
  6. 使用内存NewSQL数据平台来处理实时数据流的三个好处
  7. Python在计算内存时应该注意的问题?
  8. 动画:老大,不好了,内存泄漏了!
  9. 提高内存使用效能的技巧

随机推荐

  1. Android日志系统第三方库------Logger
  2. 其实很重要的一个分布式理论基础3pc协议
  3. 乌合之众
  4. JSON就是这么简单
  5. JVM系列(7)内存溢出问题(工作中常用、面试
  6. koa中间件与async
  7. nginx HTTPS反向代理
  8. HTTP常见面试题
  9. XML+JSON面试题都在这里
  10. 财务自由之路