GoJava

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

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

PHPcGoRPythonJavaBenchmarks热点代码28Talkischeap.Showme the code.

优缺点总结

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

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编程语言排行榜第一名了