GolangGolang开发轻松学Goland

Go的性能不如Java?

2018-07-26  本文已影响14人  freelang

Go的性能不如Java?

image

引战

今天在 知乎 上看到了一个关于 GoJava 性能对比的问题,这种问题通常只有一个结局,那就是无休止的争论,十年之后,如果这两个语言还健在的话,这可能依然是热门问题:

image

抛开应用场景谈性能都是耍流氓

目前我主要使用的也是Java和Go,方向是大数据,首先我谈一下我的看法吧:

优缺点总结

有个朋友回复的内容我觉得非常客观,也比较典型,知乎上抓过来的,侵删。

JAVA目前的问题并不在于性能,因为JIT自动优化过的代码已经跟C匹敌了。

JAVA的问题是,真正实际项目里,第三方依赖太多,架构臃肿,过度设计,这时候谁快就不好说了。

我个人认为,因为go基本上只需要标准库就足够了,实际工程中的性能表现要好于JAVA(Go的协程本质也是一种异步IO模型,Go语言: 万物皆异步),除此之外,资源占用也是性能的一部分,显然go内存占用更小,CPU消耗相对低。

benchmark game上go在大多数场景下都是跑的比Java快的,而且内存消耗是java的1/3;

来列一下Go的不足吧:

  1. 有点反程序员的语法
  2. 没有泛型
  3. 标准库中数据结构远不如Java丰富
  4. 依赖管理鸡肋
  5. channel如果使用不当,非常容易死锁
  6. 编译时不允许循环import
  7. 编码时很多包名会跟自定义的变量名冲突
  8. Java中很多认为理所当然的库,在Go中发现要重新造轮子
  9. go get命令会clone整个git仓库,包括历史commit
  10. 标准库不提供routine池
  11. 没有现成的Future机制 ,要自己通过channel实现

暂时就想到这些;当然所有这些都是可以解决的

Java的不足:

  1. 语言表达能力比较欠缺(接地气的说法叫“又臭又长”)
  2. 内存、CPU消耗大
  3. 堆内存较大时,垃圾回收器需要进行深入调优才能得到满意的回收效果; 然而在一些对实时性要求高的场景下,gc可能直接就是无解, full gc一触发就是地狱
  4. 程序需要预热
  5. JDK体积庞大, springboot jar包体积大(在微服务架构下问题最突出)
  6. Spring全家桶越来越重(Spring你做好IoC AOP就够了),导致使用全家桶的应用,性能较差(可参考TechEmpower Round 14中spring的位置),但也是足够用的
  7. 因为成熟的框架、库太多,导致很多人入门时被带偏,以为编程就是调API,用框架,而对于原理知之甚少

暂时就想到这些; 当然,Java的优点远远超过这些不足,否则就不会常年盘踞TIOBE编程语言排行榜第一名了

上一篇 下一篇

猜你喜欢

热点阅读