这是因为Go:1、语法简单;2、并发编程变得更加轻盈和安全;3、强大的标准库;4、C 语言的理念和Python的姿态;5、Go 是云计算时代的语言。Go 语言的语法特性非常简单,学习难度低,很容易上手。Go 的设计是为了弥补 C++ 的缺陷,改进各种低效和扩展性。
1、语法简单
Go 语言的语法特性非常简单,直来直去,学习难度低,很容易上手。Go 的设计是为了弥补 C++ 的缺陷,消除各种缓慢和笨重、改进各种低效和扩展性,让我们的编程变得更舒适和方便。所以它本身就具有:编译时间短,运行效率高;稳定性强,拥有强大的编译检查和完整的软件生命周期工具等优点。
2、并发编程变得更加轻盈和安全
Java 语言的编码非常繁琐,为了应用设计模式而做了大量的冗长设计。而 Go 就不一样了,它提供了便利的并发编程方式,简简单单的 Go 语句,就可以创建多个 goroutine 执行并发任务。可以说 Go 是为并发而生的。而且,Go 还提供了独特的 Channel 类型,很容易实现 goroutine 之间的数据交流。
3、强大的标准库
这里包括互联网应用、系统编程和网络编程。Go 里面的标准库基本上已经是非常稳定了,网络层、系统层的库非常实用。Go 语言的 lib 库“麻雀虽小,五脏俱全”。Go 语言的 lib 库中基本上有绝大多数常用的库,虽然有些库还不是很好,但随着技术的发展和成熟,这些问题肯定也都会随之解决。
4、C 语言的理念和Python的姿态
C 语言的理念是信任程序员,保持语言的小巧,不屏蔽底层且对底层友好,关注语言的执行效率和性能。而 Python 的姿态是用尽量少的代码完成尽量多的事。而 Go 语言则是想要把 C 和 Python 统一起来,使 Go 能兼具二者的优势之处。
5、Go 是云计算时代的语言
随着云计算平台的逐渐成熟,应用上云已经成为一个不可逆转的趋势了,很多公司都选择将基础架构 / 业务架构云化,阿里、腾讯都在将公司内部业务全面云化。可以说,全面云化已经是公司层面的核心 KPI 了,我们甚至可以理解为以后所有的技术都会围绕着云来构建。而云目前是朝着云原生架构的方向演进的,云原生架构中有 63% 的具有统治力的云原生项目都是用 Go 来构建的。
延伸阅读:
什么是Go?
Go(又称 Golang)是 Google 的 Robert Griesemer,Rob Pike 及 Ken Thompson 开发的一种静态强类型、编译型语言。Go 语言语法与 C 相近,但功能上有:内存安全,GC(垃圾回收),结构形态及 CSP-style 并发计算。
罗伯特·格瑞史莫(Robert Griesemer),罗布·派克(Rob Pike)及肯·汤普逊(Ken Thompson)于2007年9月开始设计Go,稍后Ian Lance Taylor、Russ Cox加入项目。Go是基于Inferno操作系统所开发的。Go于2009年11月正式宣布推出,成为开放源代码项目,并在Linux及Mac OS X平台上进行了实现,后来追加了Windows系统下的实现。在2016年,Go被软件评价公司TIOBE 选为“TIOBE 2016 年优异语言”。 目前,Go每半年发布一个二级版本(即从a.x升级到a.y)。
Go的语法接近C语言,但对于变量的声明有所不同。Go支持垃圾回收功能。Go的并行模型是以东尼·霍尔的通信顺序进程(CSP)为基础,采取类似模型的其他语言包括Occam和Limbo,但它也具有Pi运算的特征,比如通道传输。在1.8版本中开放插件(Plugin)的支持,这意味着现在能从Go中动态加载部分函数。
与C++相比,Go并不包括如枚举、异常处理、继承、泛型、断言、虚函数等功能,但增加了 切片(Slice) 型、并发、管道、垃圾回收、接口(Interface)等特性的语言级支持。Go 2.0版本将支持泛型,对于断言的存在,则持负面态度,同时也为自己不提供类型继承来辩护。
不同于Java,Go内嵌了关联数组(也称为哈希表(Hashes)或字典(Dictionaries) ),就像字符串类型一样。
文章标题:为什么说Go是非常适合云原生时代的编程语言,发布者:小编,转载请注明出处:https://worktile.com/kb/p/35944