Go开发工程师入门到项目实战 Google架构师联合大厂架构师出品

发布时间 2023-11-01 15:42:58作者: 天使angl

01 | Go语言课程介绍

蔡超Mobvista技术副总裁兼首席架构师,前亚马逊(中国)首席软件架构师

本节内容

你好,我是蔡超,目前在 Mobvista 担任技术副总裁兼首席架构师。在加入 Mobvista 前,我也曾在亚马逊,惠普等公司担任过首席软件架构师。

我是从小学四年级开始学习计算机编程的,并一直从事至今。学习和使用过很多的编程语言,如:BASIC,PASCAL,Perl,Python,C/C++,Java,Lisp,Haskel l 等,当然,也包括 Go 语言。

在 Mobvista ,我们使用 Go 语言构建了国内最大,全球排名前十的移动广告平台,这个平台每天处理着来自世界各地的超过 500 亿次请求。

为什么选择 Go 语言来完成这么大一个项目呢?我们不妨回到 Go 语言的源头看一看。

Go 语言的初步设想始于 2007 年,当时 Go 语言的三位创始人是想通过开发一种新型的语言来解决 Google 在软件开发中面临的问题:

  • 多核硬件架构;
  • 超大规模分布式计算集群;
  • Web 开发模式导致的前所未有的开发规模和更新速度。

这些也是目前广大互联网公司普遍面临的问题。Go 语言就是针对这些问题而设计的,所以它被越来越多的公司和组织所使用,包括阿里、腾讯、百度、滴滴等众多的业界知名公司,几乎都在自身业务中用到了 Go 语言。就在不久之前,知乎也舍弃了 Python,转用 Go 重构了推荐系统。

除了用于构建大规模互联网系统,在业界,包括大家熟知的 Docker,Kubernetes 也都是通过 Go 语言开发的,这也使得 Go 语言成为了云端应用的开发语言。另外,以太坊,HyperFabric 等著名区块链项目都可以通过 Go 语言开发,Go 也成为区块链开发中的常用语言。同时,企业应用及物联网等领域也都有 Go 语言的身影。

Go 语言的应用范围还在不断扩展,所以,今天学习和掌握 Go 语言,对于你未来的职业发展和个人成长都有着非常重要的意义。

从开发者的角度看,Go 语言有着很多为开发人员所喜爱的特性:

简单:较之 C 语言的 37 个关键字和 C++ 11 的 84 个关键字,Go 只有 25 个关键字;特别是对于一些复杂编程任务如:并发编程,内存管理,Go 语言有内置的并发支持及垃圾回收机制。

高效:Go 是编译的静态类型语言,尽管支持了垃圾回收,但 GO 中仍可以通过指针进行直接内存访问。

生产力:Go 语言有简单清晰的依赖管理,简洁的语法,以及独特的接口类型,甚至是一些编程方式的约束,如支持复合而不是继承的扩展方式,这些特性使得它成为一门极具生产力的语言。

如果你有 PHP、Java、C/C++ 等等其他一门或多门编程语言的使用经验,现在想转到 Go 语言上面,并希望学完后快速用 Go 语言进行实际的项目开发,那么这门课程非常适合你来学习。

我们会从基本的 Go 语言语法讲起,并逐步过渡到进阶部分,包括实际开发中的常见并发任务的实现,常见架构模式(pipe-filter,micro-kernel) 的实现,性能调优及高可用服务的实现等,相信你学完本课程之后,就可以快速开始使用 Go 语言进行实际项目开发了。

我身边有不少有过其他语言编程基础的工程师都开始学习和使用 Go 语言,但是正如 C 语言程序员学习 C++ 一样,由于原有习惯思维模式的影响,很多工程师在使用 Go 语言时也会常常会陷入一些误区,很多人会写出用 Go 语言表示的 C 程序或 Java 程序。

比如左边这段代码,在 C/C++ 程序员的眼里是不是觉得存在严重 Bug?可是他在 Go 程序里是完全正确的:

复制代码


  func foo() *string {
  s := "Hello World"
  return &s
  }

在实际的开发工作中,工程师们常常陷入的误区还有:

  1. 大量使用共享内存的方式进行并发控制,而忽略了 Go 内置的 CSP 并发机制;

  2. Java 程序员在编写 Go 程序喜欢在方法调用间直接传递数组,导致大量内存复制。其实,与 Java 不同,Go 的数组参数是通过值复制来传递的。

  3. Java 程序员用 Go 时也总是喜欢创建一个只包含接口定义的包,以处理依赖关系。而 这 Go 中其实大可不必,在 Go 中接口的实现对接口定义是没有依赖的。

类似的问题还有很多很多,那么针对这些问题,我在这个课程中融入了个人及团队在使用 Go 语言进行实际项目开发中的经验和教训,还会通过大量代码实例讲解 Go 语言的特性,并与其他语言的进行比较,指出它们在编程和应用上的差异。

通过这门课程,我可以帮助那些有其他语言编程基础,特别是有 C,C++ 或 Java 编程经验的工程师们打破已有的思维模式,快速掌握 Go 语言,有效利用其特性来进行实际项目的开发。

在接下来的学习过程中,也希望你多多和我留言互动,将自己碰到的问题或者学习心得分享出来,让更多的人能够从中受益。我是蔡超,我在极客时间等你。

 

02 | 内容综述

蔡超Mobvista技术副总裁兼首席架构师,前亚马逊(中国)首席软件架构师

学习资料

Go 语言官方文档 https://golang.org/doc/faq

本节内容

在 QCon2017 演讲了之后,我发现许多人对 Go 语言的学习有需求和热情,便想让更多有基础的开发者,能更快捷高效地从 Go 语言到实战开发。

于是我和极客时间合作制作了《 Go 语言从入门到实战》视频课程,我会按照下面这个路线图来带你学习,建议你可以保存至手机,随时回顾课程内容。

 

03 | Go语言简介:历史背景、发展现状及语言特性

蔡超Mobvista技术副总裁兼首席架构师,前亚马逊(中国)首席软件架构师

学习资料

Go 语言官方文档 https://golang.org/doc/faq

本节内容

通过本节课您将习得如下内容:

一、简述 Go 语言背景和发展

  1. 软件开发的新挑战
  • 多核硬件架构
  • 超大规模分布式计算集群
  • Web 模式导致的前所未有的开发规模和更新速度
  1. Go 的三位创始人

Rob Pike
Unix 的早期开发者
UTF-8 创始人

Ken Thompson
Unix 的创始人
C 语言创始人
1983 年获图灵奖

Robert Griesemer
Google V8 JS Engine 开发者
Hot Spot 开发者

二、Go 语言的特点

简单
Go 只有 25 个关键字;特别是对于一些复杂编程任务如:并发编程,内存管理,Go 语言有内置的并发支持及 GC

高效
Go 是编译的静态类型语言,并且可以通过指针进行直接内存访问

生产力
简单清新的依赖管理,简单清新的语法,以及独特的接口类型

 

04 | 编写第一个Go程序

蔡超Mobvista技术副总裁兼首席架构师,前亚马逊(中国)首席软件架构师

学习资料

Go 语言官方文档 https://golang.org/doc/faq

本节内容

通过本节课您将习得如下内容:

1. 开发环境构建

GOPATH 在 1.8 版本前必须设置这个环境变量
1.8 版本后(含 1.8)如果没有设置使用默认值
在 Unix 上默认为$HOME/go, 在 Windows 上默认为%USERPROFILE%/go

2. 基本程序结构

复制代码


  package main1 // 包,表明代码所在的模块(包)
   
  import "fmt" // 引入代码依赖
   
  // 功能实现
  func main() {
  fmt.Println("Hello World!")
  }

3. 应用程序入口

  • 必须是 main 包
  • package main
  • 必须是 main 方法
  • func main()
  • 文件名不一定是 main.go

4. 退出返回值

  • Go 中 main 函数不支持任何返回值
  • 通过 os.Exit 来返回状态

5. 获取命令行参数

  • main 函数不支持传入参数
    func main(arg []string)
  • 在程序中直接通过 os.Args 获取命令行参数