go runtime 的机制如何

u014675528 · · 4207 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

著作权归作者所有。
商业转载请联系作者获得授权,非商业转载请注明出处。
作者:qi wang
链接:http://www.zhihu.com/question/27305094/answer/36076688
来源:知乎

最近在了解Go语言的过程中,对很多语言特性的了解都涉及到Go Runtime的运行机制。在网上搜索一番之后,没有看到太多有价值的信息。除了研究源代码外,似乎没有其他的途径了。但我还是找到了一篇题为:Analysis of the Go runtime scheduler 的论文,其中部分章节介绍到了Go runtime。下面把我的理解整理一下。


先上图,这张图描述了Go语言程序,Runtime和操作系统之间的关系。



其中,Runtime管理任务调度,垃圾收集及运行环境。大家知道Go语言程序是编译为机器代码来执行的。同时,Go提供了一些高级的功能,如goroutine, channel, 以及Garbage collection。这些高级功能需要一个runtime的支持。1.4之前,runtime还是由C语言所编写的,(按照Go dev team的规划,1.5版本将去除C的代码,runtime将完全由Go语言来完成。)不论何种方式,runtime和用户编译后的代码被linker静态链接起来,形成一个可执行文件。这个文件从操作系统角度来说是一个user space的独立的可执行文件。


从运行的角度来说,这个文件由2部分组成,一部分是用户的代码,另一部分就是runtime。runtime通过接口函数调用来管理goroutine, channel及其他一些高级的功能。从用户代码发起的调用操作系统API的调用都会被runtime拦截并处理。


Go runtime的一个重要的组成部分是goroutine scheduler。他负责追踪,调度每个goroutine运行,实际上是从应用程序的process所属的thread pool中分配一个thread来执行这个goroutine。因此,和java虚拟机中的Java thread和OS thread映射概念类似,每个goroutine只有分配到一个OS thread才能运行。


事实上,go runtime非常复杂,等1.5版本出来之后,仔细研读代码,那时C的代码应该已经不存在了。会比较容易理解一些。


有疑问加站长微信联系(非本文作者)

本文来自:CSDN博客

感谢作者:u014675528

查看原文:go runtime 的机制如何

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

4207 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传