douchi7073 2019-09-19 09:59
浏览 162
已采纳

go进程产生的OS线程数量将永远不会减少吗?

Consider a golang program running on a system with GOMAXPROCS value 10. Due to blocking system calls, OS spawns 30 more threads resulting in 40 OS threads attached to the process.

After all the blocked system calls returns, then will the process still be having 40 OS threads? If yes, then can we conclude that the number of OS threads mapped to a golang process can grow but never comes down?

  • 写回答

1条回答 默认 最新

  • dongliuxia9495 2019-09-19 10:17
    关注

    Yes, currently threads spawned due to blocked goroutines are not stopped. There's a discussion about closing idle threads periodically: runtime: let idle OS threads exit #14592

    There is a way to kill a thread though. If you call runtime.LockOSThread() in a goroutine without calling its counterpart runtime.UnlockOSThread(), as per the doc:

    If the calling goroutine exits without unlocking the thread, the thread will be terminated.

    You may also do it using (source: runtime: terminate locked OS thread if its goroutine exits #20395):

    syscall.Syscall(syscall.SYS_EXIT, 0, 0, 0)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥50 汇编语言除法溢出问题
  • ¥65 C++实现删除N个数据列表共有的元素
  • ¥15 Visual Studio问题
  • ¥15 state显示变量是字符串形式,但是仍然红色,无法引用,并显示类型不匹配
  • ¥20 求一个html代码,有偿
  • ¥100 关于使用MATLAB中copularnd函数的问题
  • ¥20 在虚拟机的pycharm上
  • ¥15 jupyterthemes 设置完毕后没有效果
  • ¥15 matlab图像高斯低通滤波
  • ¥15 针对曲面部件的制孔路径规划,大家有什么思路吗