您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

使用许多goroutine消耗内存

使用许多goroutine消耗内存

runtime / debug.SetMaxStack函数仅确定对程序进行无限递归将终止的点。http://golang.org/pkg/runtime/debug/#SetMaxStack

荒谬地将其设置为最小堆栈没有任何意义,并且仅当任何堆栈的使用中大小超出限制时才由于程序崩溃而限制最大大小。

从技术上讲,崩溃仅在必须增长堆栈的情况下才会发生,因此当堆栈需要8KB以上(或在转到1.2之前为4KB)时,程序将死亡。

您的程序使用最少4KB * nGoroutine的原因是因为堆栈是页面对齐的,所以VM页面上不能有多个堆栈。因此,您的程序将至少使用nGoroutines个页面,并且OS通常仅以页面大小的增量来测量和分配内存。

更改堆栈的起始(最小)大小的唯一方法修改并重新编译go运行时(也可能是编译器)。

Go 1.3将包括连续的堆栈,通常比Go 1.2和更早版本中的拆分堆栈快,并且将来可能还会导致较小的初始堆栈。

Go 2022/1/1 18:14:42 有589人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶