写点什么

Go 的四年与成长

  • 2013-11-13
  • 本文字数:1816 字

    阅读完需:约 6 分钟

2013 年 11 月 10 日,开源项目 Go 庆祝了它的四周年纪念日(Go 第一版发布于2012 年三月;这里说的四周年,是从最初项目创建之日开始计算的)。Go 由Robert Griesemer、Rob Pike 和Ken Tompson 在Google 创建,随后Ian Taylor 和Russ Cox 也在开源之前加入了项目。以下是来自其 FAQ 的一段摘录:

Go 的诞生,源自对现有系统编程的语言和环境的挫败感。编程已经变得太过艰难,而其中部分原因应当归咎于语言的选择。开发者必须在高效编译、高效执行与易于开发之间做出抉择;然而,在主流编程语言中,并不存在一门语言能够同时实现三方面因素。侧重易用性胜过安全和效率的程序员们,会转而使用动态类型语言,例如 Python 和 JavaScript,而不是 C++,而且他们在一定程度上或许也丢开了 Java。

Go 尝试着将动态类型解释语言在编程方面的易用性,与静态类型编译语言的效率和安全性进行结合。它的目标还包括成为支持网络和多核计算的现代语言。最后,它还需要成为一门“快速的语言”:最多花费几秒钟,就能够在单台电脑上构建起大型可执行程序。要满足这些目标,必须解决大量语言问题:兼顾表达性和轻量级类型的系统;支持并发和垃圾回收;拥有严格的依赖规范;以及其他需要解决的问题。这些问题无法通过类库和工具来完美解决,只有一门全新的语言才有可能搞定这一切。

Go 当前最新版本是 2013 年 5 月发布的 1.1 版;1.2 版预计将在本月下旬问世,另外在一份兼容性文档中提到了未来的程序与Go 1 之间的兼容性,暗示了Go 所采用的兼容性的前瞻性方法,正是其他编译式语言所缺乏的。

从发布到现在,已经有许多公司开始使用Go,例如轻量容器中的应用打包工具 Docker 、自动创建机器映像的 Packer 、提供分布式信息发送平台的 Bitly’s NSQ 、提供基础设施自动化的 Canonical’s JuJu ,以及其他许多公司。甚至自由软件基金会也在谈论用Go 取代Java 作为默认语言。Docker 团队也在一场演讲中,阐述了为何他们会选择使用Go。

而对DevOps 人群来说,其主要价值在于,Go 程序永远静态地链接到单一可执行程序中——该程序可被部署在目标平台上。因此,系统并不需要预先安装任何额外二进制文件,也无需操心同时运行不同版本的程序会产生冲突。这个特性能够与像Linux 和Java 这样的打包系统相媲美——它们拥有覆盖多个位置的类库,并要求特定的安装位置,或是一个用来预先构建路径的解析器。(下行风险是,在所有程序的静态二进制文件中,通用类库不断重复出现;但同时硬盘空间的价格并不昂贵。相反,对于运行许多进程的系统来说,服务器上的内存压力或许是更现实的问题——不重复载入某个类的映像,而是只载入一次的话,将有效减少内存压力。幸而,Devops 工具一般并不会长时间运行。)

对高可用性和多线程程序来说,主要好处是Go 的 goroutines ——它采用与 Erlang 或 Occam 相似的方式,允许执行多线程来服务收到的请求。这三者都是基于 Hoare 的通讯顺序进程( Communicating Sequential Processes ),简称 CSP。CSP 并不处理内存和进程访问,相反,每个 CSP 都拥有一个消息 / 任务的传入队列,并且能够依次将这些消息 / 任务发送给其他 CSP。CSP 支持阻塞和异步操作;每个(阻塞的)CSP 都拥有一个返回值,一般被作为返回消息发送给始发的 CSP。

Cloud Foundry 最近把它的命令行工具从Ruby 换成了Go ,以实现无需任何特定前置条件极可使用命令的目的。实际上,现在它是一个用来与后端服务沟通的轻量级工具;而且现在不再由客户端来执行复杂的验证程序,而是由它与后端沟通来完成繁重工作。这意味着该工具现在不再需要频繁升级,同时体积也得以缩小。

随着 Go 1.2 即将在下周到来,该语言也做出了改变:增加了对三索引切片(slice)的支持。此前,表达式 a[1:10] 将把数组中的 1 到 10 个元素进行切片;而现在 a[1:2:10] 将以间隔方式切出元素。一项细小的澄清是,对于使用 nil 的地方,如果取消引用会引起恐慌。其他变化请参考发行注记

一些针对的Go 批评家指出,该语言使用了一种旧式的编程返回码风格,而不是得到更广泛采用的基于异常的风格;另外与Erlang(函数式编程,没有可变状态)不同,goroutines 能够传送字典(map)。由于默认情况下字典是非同步的,因此这有可能会导致内存冲突。不过,目前很明确的是,Go 非常适合针对特定细分领域的用例;而且无论从哪方面与Java 和Erlang 这样的语言进行对比,Go 都可以被看作轻量级语言;同时,与纯C 相比,Go 或许是个更安全的选择。

查看英文原文: Go Fourth and Grow

2013-11-13 04:293201
用户头像

发布了 256 篇内容, 共 84.3 次阅读, 收获喜欢 10 次。

关注

评论

发布
暂无评论
发现更多内容

瓦力量化交易机器人软件开发|瓦力量化交易机器人APP系统开发

系统开发

滴滴Kafka服务体系建设,实战干货都在这里!

滴滴云

大数据 Obsuite 滴滴Kafka

应云而生,幽灵的威胁 - 云原生应用交付与运维的思考

阿里巴巴云原生

云计算 容器 微服务 云原生 k8s

区块链技术在各国政府管理中的运用

CECBC

区块链

又长又细,万字长文带你解读Redisson分布式锁的源码

数据库 redis 架构

敏捷团队实践

Teobler

项目管理 敏捷 敏捷开发 工程实践 敏捷开发管理

利用xml实现数据传输

天狼

产业数字金融的数字化与生态化

CECBC

金融

备战金三银四,阿里,腾讯春招面试题解析,含Java岗988道题分享

Java 架构 面试

小步发布、验收测试和完整团队

Teobler

项目管理 敏捷 敏捷开发 工程实践 敏捷开发管理

真实!对比(阿里/京东等一线大厂)Java面试真题,自己把自己菜哭了

Java架构之路

Java 程序员 架构 面试 编程语言

逆向思维:从小厂到面试大厂,这份学习笔记助我快速成长,实现高薪岗位

Java架构之路

Java 程序员 架构 面试 编程语言

华为发布智能云网“五个一”新能力,助力运营商完成云与网的价值归一

脑极体

一名叫谙忆的程序员在2021年的具体安排《打工人的那些事》

谙忆

【科技改变生活,区块链改变世界】欧科云链徐明星的区块链密码朋克世界

CECBC

区块链

币管家软件开发|币管家系统APP开发

系统开发

双指针高频面试题:三数之和的「升级篇」...

宫水三叶的刷题日记

面试 LeetCode 数据结构与算法

OpenYurt 如何 “0 侵入” 攻破云边融合难点

阿里巴巴云原生

云计算 Serverless 容器 云原生 边缘计算

滴滴开源 LogicFlow:专注流程可视化的前端框架

滴滴技术

源码解析--skywalking agent插件加载流程

cloudcoder

Skywalking 源码剖析 插件设计

“他者”德意志(一):“进窄门”的德国AI

脑极体

首全网发!2021最新版美团面经刷题笔记,已霸榜GitHub

比伯

Java 编程 架构 面试 程序人生

Docker 镜像加速教程

硅基新手村

Docker 云原生

网格量化交易机器人系统开发|网格量化交易机器人软件APP开发

系统开发

卓越级!浪潮云通过可信云云管理服务能力评估

基于WASM的无侵入式全链路A/B Test实践

韩陆

敏捷业务实践之计划游戏

Teobler

项目管理 敏捷 敏捷开发 敏捷开发管理

insert、update、delete注入总结

Cc.

网络安全

数字货币量化交易APP开发|数字货币量化交易系统软件开发

系统开发

容器 & 服务:Docker 应用的 Jenkins 构建(二)

程序员架构进阶

容器 服务化 七日更 28天写作 2月春节不断更

CIO/CTO必读 | 数字转型时代,企业存储支出知多少

焱融科技

存储 焱融科技 CIO 存储成本 IT成本

Go的四年与成长_DevOps & 平台工程_Alex Blewitt_InfoQ精选文章