duanhongxian6982 2019-06-08 00:46
浏览 191
已采纳

在golang中声明一个空的map [string] interface {}的内存成本/开销是多少? [重复]

This question already has an answer here:

Asking just for curiousity, from the source code

type hmap struct {
    count     int // 1 word
    flags     uint8
    B         uint8  
    noverflow uint16 
    hash0     uint32 // = 8 byte

    buckets    unsafe.Pointer // 1 word
    oldbuckets unsafe.Pointer // 1 word
    nevacuate  uintptr        // 1 word

    extra *mapextra // 1 word
}

so it would at least: 5 word + 8 byte

but why the creation cost is 0? -


package main

import (
    "fmt"
    "runtime"
)

func main() {
    var m1, m2 runtime.MemStats
    var i byte

    runtime.ReadMemStats(&m1)
    mp := map[byte]byte{}
    runtime.ReadMemStats(&m2)
    fmt.Println("Bytes allocated on creation:", m2.Alloc-m1.Alloc)
    for i = 0; i < 100; i++ {
        runtime.ReadMemStats(&m1)
        mp[i] = i
        runtime.ReadMemStats(&m2)
        fmt.Printf("Bytes allocated on assignment %d: %d
", i, m2.Alloc-m1.Alloc)
    }
}

Playground: https://play.golang.org/p/iyYshDzexQt

Output:

Bytes allocated on creation: 0
</div>
  • 写回答

1条回答 默认 最新

  • dongliao9018 2019-06-08 02:13
    关注

    why the creation cost is 0?

    A Go stack allocation allocates zero bytes on the heap.

    mp := map[byte]byte{}
    
    main map[byte]byte literal does not escape
    

    package main
    
    import (
        "fmt"
        "runtime"
    )
    
    func main() {
        var m1, m2 runtime.MemStats
        var i byte
    
        runtime.ReadMemStats(&m1)
        mp := map[byte]byte{}
        runtime.ReadMemStats(&m2)
        fmt.Println("Bytes allocated on creation:", m2.Alloc-m1.Alloc)
        for i = 0; i < 100; i++ {
            runtime.ReadMemStats(&m1)
            mp[i] = i
            runtime.ReadMemStats(&m2)
            fmt.Printf("Bytes allocated on assignment %d: %d
    ", i, m2.Alloc-m1.Alloc)
        }
    }
    

    Playground: https://play.golang.org/p/iyYshDzexQt

    Output:

    Bytes allocated on creation: 0
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 做个有关计算的小程序
  • ¥15 MPI读取tif文件无法正常给各进程分配路径
  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
  • ¥15 setInterval 页面闪烁,怎么解决
  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化