Go 語言學習技巧和編程思維
一、了解 Go 語言
了解 Go 語言背景
學習 Go 語言,首先要了解 Go 語言,Go 是于 2009 年 11 月開源,然后最終在 2012 年上半年的時候發(fā)布了 Go 1.0 穩(wěn)定版本,主要是由 Google 主導開發(fā)。目前 Go 有一個非?;钴S的社區(qū),現(xiàn)在很多互聯(lián)網(wǎng)公司的后端開發(fā)很多都是用 Go 語言開發(fā)了,當然了,這個目前還動搖不了 Java 的統(tǒng)治地位。
Go 發(fā)展勢頭這么快,更多的是得益于云原生,因為當前階段云原生已經(jīng)是風生水起,而云原生相關系統(tǒng)的實現(xiàn),絕大多數(shù)都是 Go 來實現(xiàn)的,比如 K8s、Istio、Docker、Etcd 等。
探討 Go 的未來
我們去看一種語言能不能有一個好的未來,主要看如下幾點:
- 社區(qū)是否活躍和豐富、開發(fā)者們是否能夠接收社區(qū)的一些建議。目前發(fā)展勢頭較好的語言,比如 Java、C/C++ 社區(qū)一定是非常活躍的,參與的人數(shù)會非常多,并且也能很好的和社區(qū)進行交換意見。
- 是否有一些工業(yè)化的標準。像 C/C++、Java 這些編程語言都是有標準化組織的。尤其是 Java,它在架構上還搞出了像 J2EE 這樣的企業(yè)級標準。
- 是否有一些重量級的應用項目。常見發(fā)展好的語言一定都是有大量的重量級項目的。
- 是否有重量級人物或者公司牽頭。
- 是否容易上手。
對比來看,Go 目前的社區(qū)非?;钴S,主要由 Google 牽頭,并且能夠很好的接收社區(qū)的意見并且進行優(yōu)化改進,并且目前很多大公司內部也都大量使用 Go,整體語言非常簡單易懂,并且開發(fā)效率高,而 Go 語言的重量級應用比如 Kubernetes 、Istio 、Docker 都是目前火爆的不行的。所以, Go 的未來是非??捎^的。但是,Go 也不至于會讓其他語言都無處容身,Go 更多的會在云原生相關領域,以及 PaaS 層的相關領域上有絕對性的優(yōu)勢,后續(xù)的一些后端中間的基礎組件可能大多數(shù)都會使用 Go 來開發(fā)了。
二、Go 語言學習技巧
了解各語言的優(yōu)缺點
對技術人員而言,學習一門新語言,必然需要掌握這門語言的一些優(yōu)缺點,以及其他類似語言的優(yōu)缺點,有對比才能讓你更快的理解這門語言
Go 語言的優(yōu)缺點
Go 優(yōu)點:學習門檻低,非常簡單直接,表達力很強,并且語言特定比較穩(wěn)定,社區(qū)活躍,基本上想要的一些組件或者通用庫,都能在官方包或者 github 上找到。不用關心內存分配和釋放,gc 會幫我們處理。并且還可以兼容 C ,不過,一般實際應用中很少會使用兼容 C 的使用姿勢,要么純 Go、要么純 C。Go 另外一個比較大的優(yōu)勢在于支持協(xié)程,可以非??焖俚膶懗霾l(fā)高的代碼,Go 的并發(fā)非常簡單。Go 在以前的版本最受大家詬病的泛型,也在 Go1.18 開始支持了,這個算的上是他的一個優(yōu)點了。
Go 缺點:目前在兼容 C 的情況下的高并發(fā)的支持上做的還不夠好。目前 Go 基本只能應用在后端開發(fā),無法應用在客戶端的開發(fā),也很少有在 PC 端的開發(fā)。當然,有一些語法和習慣比較讓人詬病,比如 err 的處理,但是習慣了以后,其實感覺還好。
C/C++ 語言的優(yōu)缺點
- C/C++ 的優(yōu)點:功能強大,性能高,C 相對簡單點,C++ 會比 C 復雜很多。很多底層的一些實現(xiàn)都是 C/C++,因為 C/C++ 更偏向底層,歷史悠久,早些年的大學學的大多數(shù)是 C/C++ 語言,社區(qū)資源豐富。搞 C++ 厲害的都是大神。
- C/C++ 的缺點:指針非常靈活,很多人用不好,相對來說要用好 C 的話門檻還是比較高,尤其是 C++ 的門檻。另外一方面是需要自己手動管理內存的申請和分配,一不小心就會內存泄漏或者段指針錯誤。
Jave 語言的優(yōu)缺點
- Java 優(yōu)點:程序員最多,社區(qū)資源豐富。內存管理基于 GC,和 Go 一樣,不用自己管理,這大大減少了使用的心智負擔?;?VM 字節(jié)碼,天然提供了跨平臺的插件機制。
- Java 缺點:強 OO 流派,表達上有些死板,不夠活潑(不是靈活)。
Go 語言學習技巧和步驟
- 了解 Go 的一些基本情況后,接下來我們看看怎么學習 Go。學習 Go 首先,要把 Go 的基本語法弄清楚,這個可以看一些入門的書籍,把 Go 的基礎數(shù)據(jù)結構有個大致了解。
- 通讀 Go 的一些好的文章如 Frequently Asked Questions (FAQ)或者看看 FAQ 的中文翻譯 ,主要是了解 Golang 的全貌。
- 關注 Go 語言的編碼規(guī)范,任何一門語言,一定要注重它既有的編碼規(guī)范和慣用法。首先需要了解 Go 官方的編碼規(guī)范,主要是要參考官方的 CodeReviewComments 和 Effective Go 這兩篇官方文章,真的非常推薦必須要好好的看完、看懂這兩篇文章(英文不好的同學可以看中文翻譯文檔),然后按照官方編碼規(guī)范來具體 coding。規(guī)范的目的主要是能夠在具體的編碼中有跡可循, 一般的大公司,都會有內部的編碼規(guī)范,內部的 Go 編碼規(guī)范也是再官方的基礎上做一些優(yōu)化或者定制。
-
有了基本語法,有了編碼規(guī)范,那么接下來就需要我們去參考業(yè)界大牛們的代碼,主要是看一些開源的優(yōu)質的項目,比如 Google 他們這幫人自己搞的 Kubernetes、Istio,還有一些好的項目如 Docker、CoreDNS、etcd 等等,具體要看這些東西:
- 項目基本架構的組織
- 代碼基本的編碼封裝
- 代碼的基本原則規(guī)范
- 并發(fā)的設計思想
- 面向對象編程的設計思想
- 可擴展性的設計思想
最后就是要動手實踐,實實在在的跑一些代碼示例,一般我的習慣是自己建立一個 base-code 的項目,里面就是我們的各種 example 示例,然后進行一些修改、執(zhí)行。具體的代碼示例可以從官方文檔上來,推薦Go by Example,里面有大量非常好的例子。也可以自己網(wǎng)上隨便搜下,重要的自己要修改并執(zhí)行,查看和分析結果,然后再 Go 101這里有各個語法的使用和介紹
三、Go 語言價值觀和編程思維
編程語言會影響編程思維,對于 Go,最重要的思維就是并發(fā)思維,因此,學習 Go,就要用 Go 的編程思維去寫 Go 代碼,而不是用其他語言的思維方式【Golang coding in go way】。
Go 語言的初衷就是為了解決好 Google 內部大規(guī)模高并發(fā)服務的問題,主要核心就是圍繞高并發(fā)來開展;并且同時又不想引入面向對象那種很復雜的繼承關系。所以,這正是 Go 編程思維的來源。
-
Go 天生就是可以方便的解決好并發(fā)問題(包括高并發(fā)),那么就需要有并發(fā)思維,能夠并發(fā)處理就通過并發(fā)來進行任務分配
- 這里就涉及到了 context、 goroutine、channel(select) 等的原理和設計,雖然,在 Go 里面可以創(chuàng)建大量 goroutine, 但是,一般我們都需要能通過 context、 channel 建立 "父子"關系,用來控制其生命周期,保證子任務可以能夠被回收、被主動控制(如 殺死)
-
需要有面向對象編程思想,利用好 interface、 struct 來實現(xiàn)繼承、多態(tài)的用法
- struct 匿名組合來實現(xiàn)繼承
- interface 和 struct 來實現(xiàn)多態(tài)
- interface 定義接口,盡可能的保持里面的方法定義簡單,然后多個 interface 進行組合
-
理解 Go 語言的一些獨有特性和慣用法:
- 按照官方和內部的編碼規(guī)范來使用,熟悉它的各種慣用法
- 強類型,語法上要注意處理
- 一定要關注 GC,實際中要觀察 GC 日志并做好分析
- Go 是有 Runtime 的,所以得了解 Runtime 的原理和運行機制
-
理解 Go 語言的價值觀
- 價值觀 1:盡可能的簡單
- 語法語義盡可能的簡單、保持各種類型定義盡可能精簡
- 短命名思維,在不影響可讀性的前提下,盡可能的用長度短小的標識符,一個例子就是
for i, u := range users {
- 價值觀 2:進行正交組合,優(yōu)先考慮組合,而不是常見 OO 語言的繼承方式
- Go 語言通過類型的垂直組合而不是繼承讓單一類型可以承載更多的功能
- interface 盡可能的保持職責單一并且接口里面的方法不要過多
- 價值觀 3:大膽使用并發(fā),Go 是為并發(fā)而生的(Goroutine 機制)
- 價值觀 1:盡可能的簡單
-
從 Golang 社區(qū)的一些最佳實踐來看,Golang 的各種組件也需要盡可能的精簡。
- Golang 中用好的一些開源組件庫,都是比較輕量級的,然后可以各自隨意組合來達到最佳實踐。
- 我們自己進行組件封裝、模塊封裝的時候,也是保持這個原則,盡可能的精簡,然后使用方進行組合。
參考
最后
這篇文章首發(fā)在我微信公眾號【后端系統(tǒng)和架構】中,點擊這里可以去往公眾號查看原文鏈接,如果對你有幫助,歡迎前往關注,更加方便快捷的接收最新優(yōu)質文章