go语言完虐java,为什么学go语言你真的清楚吗?
Posted 老男孩Linux
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了go语言完虐java,为什么学go语言你真的清楚吗?相关的知识,希望对你有一定的参考价值。
师出有名
就是这三个牛逼哄哄的人物
Go的三个作者从左到右分别是
Robert在开发Go之前是Google V8、Chubby和HotSpot JVM的主要贡献者;
Rob主要是Unix、UTF-8、plan9的作者
Ken主要是B语言、C语言的作者、Unix之父
痛点突出,激发欲望
设计Go语言是为了解决当时Google开发遇到的以下这些问题:
大量的C++代码,同时又引入了Java和Python
成千上万的工程师
数以万计行的代码
分布式的编译系统
数百万的服务器
其主要有以下几个方面的痛点:
编译慢
失控的依赖
每个工程师只是用了一个语言里面的一部分
程序难以维护(可读性差、文档不清晰等)
更新的花费越来越长
交叉编译困难
亮点突出
最后根据实战经验,他们向着目标设计了Go这个语言,其主要的特色有:
没有继承的OO
强一致类型
Interface但是不需要显示申明(Duck Type)
Function 和Method
没有异常处理(Error is value)
基于首字母的可访问特性
不用的Import或者变量引起编译错误
完整而卓越的标准库包
Go发布之后,很多公司特别是云计算公司开始用Go重构他们的基础架构,很多都是直接采用Go进行了开发,最近热火朝天的Docker就是采用Go开发的。我们来看看目前为止采用Go的一些国内外公司,国外的如Google、Docker、Apple、Cloud Foundry、CloudFlare、Couchbase、CoreOS、Dropbox、MongoDB、AWS等公司,国内的如阿里云CDN、百度、小米、七牛、PingCAP、华为、金山软件、猎豹移动、饿了么等公司。
可应用系统多
就知道的来说,目前Go主要应用在下面这些系统:
服务器编程,以前你如果使用C或者C++做的那些事情,用Go来做很合适,例如处理日志、数据打包、虚拟机处理、文件系统等。
分布式系统、数据库代理器等,例如Etcd。
网络编程,这一块目前应用最广,包括Web应用、API应用、下载应用,而且Go内置的net/http包基本上把我们平常用到的网络功能都实现了。
数据库,前一段时间Google开发的Groupcache,Couchbase的部分组建,Tidb,Cockroachdb,Influxdb等。
云平台,目前国外很多云平台在采用Go开发,CloudFoundy的部分组建,前VMare的技术总监自己出来搞的Apcera云平台。
更多IT技术性文章和福利活动
点击“阅读原文”带你装X带你飞
以上是关于go语言完虐java,为什么学go语言你真的清楚吗?的主要内容,如果未能解决你的问题,请参考以下文章