Go
编译生成的是一个静态可执行文件,除了glibc外没有其他外部依赖。这让部署变得异常方便:目标机器上只需要一个基础的系统和必要的管理、监控工具,完全不需要操心应用所需的各种包、库的依赖关系,大大减轻了维护的负担。
2. 并发性好
Goroutine和channel使得编写高并发的服务端软件变得相当容易,很多情况下完全不需要考虑锁机制以及由此带来的各种问题。单个Go应用也能有效的利用多个CPU核,并行执行的性能好。
3. 良好的语言设计
从学术的角度讲Go语言其实非常平庸,不支持许多高级的语言特性但从工程的角度讲,Go的设计是非常优秀的:规范足够简单灵活,有其他语言基础的程序员都能迅速上手。更重要的是
Go 自带完善的工具链,大大提高了团队协作的一致性。
4. 执行性能好
虽然不如 C 和 Java,但相比于其他编程语言,其执行性能还是很好的,适合编写一些瓶颈业务,内存占用也非常省。
Go和java产生的背景和语言的定义不一样,比较他们的好坏没多大意义,适合就是最好的,当你去做一个大型的项目的时候,使用java能够更清晰地展示出你的业务。自身提供了比较完善的库。Go语言也有面向函数和面向对象的变成方案,其自身的性能决定了go语言更适合做中间件,底层的各种框架。
语言对企业来说,是制造生产力的,哪种语言能够给我们带来更好的收益,我们才选择它们。