zoukankan      html  css  js  c++  java
  • 走进 Google 的 Go 语言

    摘要:本文整理自Google首席工程师Rob Pike的演讲Slide,主要讲述的了Go的部分设计原理和初衷,也有提到Go语言在Google内外的应用现状。但本文的目的更多的是关于软件工程而不是编程语言的设计,更准确地说是如何设计编程语言来帮助软件工程。


    序言:关于Go


    Go语言是一个开源、并发、高效、简单、有趣(但对某些人来说可能很无聊)的编程语言,支 持垃圾回收(GC),具有很好的可伸缩性。Go是从2007年末由Robert Griesemer, Rob Pike, Ken Thompson主持开发,后来还加入了Ian Lance Taylor, Russ Cox等人,并最终于2009年11月开源,在2012年早些时候发布了Go 1稳定版本。现在Go的开发已经是完全开放的,并且拥有一个活跃的社区。

    Go最初是为了解决Google的问题而开发的,要知道Google面临着很多大问题。Google的中服务器最主要是C++编写的,除此之外还 有 很多Java、Python代码。另外,Google还有数千名工程师、无数行代码、庞大的分布式构建系统以及数不清的机器(我们认为相对于一个中等规模 的集群)。Google的开发可能很慢,甚至笨拙,但它总是很有效。

    所以毫无疑问Go对“大硬件”的支持非常好,也适合“大软件”的开发。CSDN之前也编译了一批Rob Pike的文章——Go语言之父谈Go:大道至简,在这里Rob描述了Go的创作起源和初衷。

    为什么应该用Go?


    Go是为了帮助人们阅读、调试和维护大型软件系统而生的,所以目标是

    • 不再缓慢
    • 不再笨拙
    • 提高效率
    • 保持(甚至提升)扩展性

    但是在使用C++或者Java开发中却常常遇到各种问题:

    1. 构建缓慢
    2. 依赖性难以控制
    3. 每个编程语言都使用不同的语言子集
    4. 程序难以理解(文档等原因)
    5. 重复工作
    6. 更新成本高
    7. 版本交叉
    8. 自动化不方便(工具问题)
    9. 跨语言构建

    而Go语言则是为了解决这些问题而设计的。

    另外,C语言的依赖一直是个大问题,包括依赖叠加、编译时引入依赖的情况都很难处理,同时你也没办法查清哪些依赖是可以删除的,那些不可以。在C++中,这一点变得更加明显:

    • 每个类里都有#include文件
    • #include文件中有代码(而不仅仅是声明)
    • #ifndef的残留

    所以一直无法在一台机器上构建大型Google二进制。(To build a large Google binary on a single computer is impractical.)

    当然,工具确实很有帮助,于是做了如下改进:

    • 新的分布式构建系统
    • 不再需要Makefile(但仍然使用BUILD文件)
    • 多缓存
    • 多复杂度(大程序本身所具有的)

    即使在Google的分布式构建系统的的帮助下,大型构建工程依然会花费不少时间(以其中一个二进制文件为例,在2007年花了45分钟,现在是27分钟)。生活质量还是太低。

    走进Go语言


    我们都希望拥有更高质量的生活,所以必须解决这些问题,所以就有了最初的想法:

    • 必须是可扩展的
    • 适合大型程序、大型团队以及拥有大量依赖的应用
    • 必须易于接近,例如接近C语言那样。
    • 现代化
    • 适合多核机器
    • 适合网络机器
    • 适合Web开发

    Go语言的设计是以软件工程为目标,所以它有这些优点:

    • 清晰的依赖
    • 清晰的语法
    • 清晰的语义学
    • 简单的模型(垃圾回收和并发性)
    • 便捷的工具(go tool、gofmt、godoc、gofix等)

    还有那些问题?


    Go语言目前所面临的最大问题在于,还没有足够的经验来证明Go是否真的是一个成功的产 品,缺少大型应用实践。但是在Google内部,如golang.org、youtube.com、dl.google.com都已经开始使用Go语言开 发,除此之外还有一些其它小应用(有的是在GAE上)也选择使用Go;而在Google之外,BBC Worldwide、Canonical、Heroku、Nokia、SoundCloud也都在尝试Go。

    总而言之,Go是由软件工程驱动的编程语言,但富有成效并且有趣,这样的设计非常高产。

    Rob Pike演讲的Slide可以在这里看到。

     

  • 相关阅读:
    Tornado入门2
    Tornado框架入门
    Nginx下载及安装
    串口通信工程笔记一
    串口通信工程笔记之协议设计
    串口通信之并发与单步
    串口通信属性及事件解析
    串口通信之超时
    VC程序Debug版本和Release版本运行不一致问题
    串口通信之DataReceive事件触发时机
  • 原文地址:https://www.cnblogs.com/shihao/p/2750864.html
Copyright © 2011-2022 走看看