目前,当Go需要和C/C++代码集成的时候,大家最先想到的肯定是CGO。毕竟是官方的解决方案,而且简单。

但是CGO是非常慢的。因为CGO其实一个桥接器,通过自动生成代码,CGO在保留了C/C++运行时的情况下,搭建了一个桥来沟通C/C++世界和Go的世界。这就意味着,兼容性很好,但是对C的函数的调用,必须先把当前的goroutine挂起,并切换执行栈到当前的线程M的主栈(大小2MB)。如果不做这个操作,那么只能在goroutine的栈上执行C函数调用,可是,goroutine的栈一般都很小,很容易就导致了栈溢出了。

调用C函数的时候,必须切换当前的栈为线程的主栈,这带来了两个比较严重的问题:

  1. 线程的栈在Go运行时是比较少的,受到P/M数量的限制,一般可以简单的理解成受到GOMAXPROCS限制;
  2. 由于需要同时保留C/C++的运行时,CGO需要在两个运行时和两个ABI(抽象二进制接口)之间做翻译和协调。这就带来了很大的开销。

minio项目的一个副产品是 c2goasm 项目,这个项目也被 go-cv-simd 项目使用获得了很好的效果。

c2goasm 的角色是一个 汇编语言转换器,输入是 clang输出的amd64汇编,输出是go汇编。而clang的输入是C/C++语言。限制是不能有RTTI和异常。也就是说不能有C/C++运行时提供的高级功能。

c2goasm输出的go汇编,交给go的工具链可以直接生成go的可执行代码。

c2goasm和CGO比,最大的改进就是:

  1. 不再有C/C++运行时,也就没了在两者之间不停转换的逻辑开销;
  2. 不需要切换到线程的主栈来执行函数,因为c2goasm生成的是纯正的go函数,不需要线程的主栈就可以执行;

由此就极大的改进了性能,代价是兼容性和可移植性损失了。

https://my.oschina.net/linker/blog/1529928

最新文章

  1. 【无私分享:ASP.NET CORE 项目实战(第二章)】添加EF上下文对象,添加接口、实现类以及无处不在的依赖注入(DI)
  2. WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED
  3. 2015年第5本(英文第4本):Death on the Nile尼罗河上的惨案
  4. cf------(round)#1 C. Ancient Berland Circus(几何)
  5. Java Concurrency - invokeAny & invokeAll
  6. 启动android程序和虚拟机时候出现如下错误的解决方法
  7. FreeBSD方式安装 MAC OSX
  8. JS获取终端屏幕、浏览窗口的相关信息
  9. Stream-快速入门Stream编程
  10. Resin文档阅读笔记
  11. java第五次笔记
  12. MySQL高级知识(一)——基础
  13. doy09 文件处理,拷贝文件
  14. [PHP] 数据结构-线性表的顺序存储结构PHP实现
  15. JS中什么是发布--订阅模式?
  16. Let's Encrypt 免费通配符 SSL 证书申请教程——但是也需要email,域名所有权等,如果是黑产用的话会这样用吗?会不会暴露自己身份???
  17. 查询 EBS 系统物料净重、毛重
  18. 通过ffplay实现摄像头preview
  19. HTML代码转义(JAVA)
  20. windows7 通过WSUS服务器更新,报错,错误代码800b0001

热门文章

  1. VMware虚拟机12安装linux系统详细教程
  2. php 获取提交来源,判断从哪里提交的
  3. Cisco IOS images
  4. VBA Code for Word Navigation Pane 【failed】 view-showheading-method-word
  5. 常用binlog日志操作命令
  6. 【codeforces 765D】Artsem and Saunders
  7. 学习鸟哥的Linux私房菜笔记(9)——bash1
  8. 【p093】细胞分裂
  9. Java String对象的经典问题(转)
  10. 第二十一篇:基​于​W​D​M​模​型​的​A​V​S​t​r​e​a​m​驱​动​架​构​研​究