百科问答小站 logo
百科问答小站 font logo



如何评价 Golang 1.5 更新? 第1页

  

user avatar   yangzhe1991 网友的相关建议: 
      

我觉得最大的意义应该是1.5的GC的STW时间明显下降了。从我之前在

wandoulabs/codis · GitHub

的测试结果来说,client并发数比较低的时候最大延迟基本上取决于STW的时间,在我自己的macbook上测,1.3和1.4的最大延迟是4ms和7ms,而1.5不到1ms。为了实现并发收集,1.4里给指针加了个write barrier从而影响了性能,然而1.4的并发收集又没做,于是1.4变成了一个半成品,性能(吞吐)很多场景比1.3差,而GC的停顿时间又没减少,非常蛋疼……

另外那条“默认 Go 程序使用 GOMAXPROCS 变量来设置CPU核数,之前默认是1”,并不是单纯的一个默认值的改动让你减少一行蛋疼的代码这么简单。他基于一个前提是现在goroutine的调度器的性能已经越来越好。见

docs.google.com/documen

,如果调度器性能不行,在一些场景可能会出现一种情况,就是在goroutine数量相同的情况下,用的CPU越多也就是开的线程越多,性能反而变差(见里面的表格)。而go的开发者目前认为,1.5的调度器性能nb了很多,在各种测试场景上已经不会导致多核比单核还差很多,于是改了默认值。




  

相关话题

  Node.js、Scala、Clojure 等声称适合高并发的语言,分别具体适用于什么情景,何种任务? 
  为什么说C++的main函数最后不写 return 0; 是不好的习惯? 
  多核CPU中,利用多线程进行排序中出现了一些奇怪的现象,不知道其背后的原因是什么,希望有人能给予解答? 
  为什么华为不请王垠去设计新的编程语言? 
  Go1.6中的gc pause已经完全超越JVM了吗? 
  如何看待一五年级小学生称其自创编程语言,实际完成度如何? 
  google play 账号怎么解除国家绑定? 
  有哪些c++的书推荐? 
  如何评价 DeepMind arXiv 论文公开的 AlphaZero 击败国际象棋和将棋的最强引擎? 
  如何通俗易懂解释 Java 语言所谓「一次编写,到处运行」的特性? 

前一个讨论
为什么日本没像德国那样对发动二战做出正式忏悔?
下一个讨论
大礼议中为什么杨廷和一定要让嘉靖认孝宗为父?究竟争的是什么?





© 2025-01-29 - tinynew.org. All Rights Reserved.
© 2025-01-29 - tinynew.org. 保留所有权利