為什么要開發 Go 這門新語言?
本文轉載自微信公眾號「腦子進煎魚了」,作者陳煎魚。轉載本文請聯系腦子進煎魚了公眾號。
大家好,我是煎魚。
大家平時都是在用 Go 語言,那以往已經有了 C、C++、Java、PHP。Google 的大佬們為什么還要再開發一門新的語言呢?
難不成是造輪子,其他語言不香嗎?
背景
Go 編程語言構思于 2007 年底,構思的目的是:為了解決在 Google 開發軟件基礎設施時遇到的一些問題。
Go 語言之父
圖上三位是 Go 語言最初的設計者,功力都非常的深厚,按序從左起分別是:
- Robert Griesemer:參與過 Google V8 JavaScript 引擎和 Java HotSpot 虛擬機的研發。
- Rob Pike:Unix 操作系統早期開發者之一,UTF-8 創始人之一,Go 語言吉祥物設計者是 Rob Pike 的媳婦。
- Ken Thompson:圖靈獎得主,Unix 操作系統早期開發者之一,UTF-8 創始人之一,C 語言(前身 B 語言)的設計者。
遇到的問題
曾經在早期的采訪中,Google 大佬們反饋感覺 "編程" 太麻煩了,他們很不喜歡 C++,對于現在工作所用的語言和環境感覺比較沮喪,充滿著許多不怎么好用的特性。
具體遭遇到的問題。如下:
- 軟件復雜:多核處理器、網絡系統、大規模計算集群和網絡編程模型所帶來的問題只能暫時繞開,沒法正面解決。
- 軟件規模:軟件規模也發生了變化,今天的服務器程序由數千萬行代碼組成,由數百甚至數千名程序員進行工作,而且每天都在更新(據聞 Go 就是在等編譯的 45 分鐘中想出來的)。
- 編譯耗時:在大型編譯集群中,構建時間也延長到了幾分鐘,甚至幾小時。
設計目的
為了實現上述目標,在既有語言上改造的話,需要解決許多根本性的問題,因此需要一種新的語言。
這門新語言需要符合以下需求:
- 目的:設計和開發 Go 是為了使在這種環境下能夠提高工作效率。
- 設計:在 Go 的設計上,除了比較知名的方面:如內置并發和垃圾收集。還考慮到:嚴格的依賴性管理,隨著系統的發展,軟件架構的適應性,以及跨越組件之間邊界的健壯性。
這門新語言就是現在的 Go。
Go 在 Google
Go 是 Google 設計的一種編程語言,用于幫助解決谷歌的問題,而 Google 的問題很大。
Google 整體的應用軟件很龐大,硬件也很龐大,有數百萬行的軟件,服務器主要是 C++ 語言,其他部分則是大量的 Java 和 Python。
數以千計的工程師在代碼上工作,在一個由所有軟件組成的單一樹的 "頭 " 上工作,所以每天都會對該樹的所有層次進行重大改變。
一個大型的定制設計的分布式構建系統使得這種規模的開發是可行的,但它仍然很大。
當然,所有這些軟件都在幾十億臺機器上運行,這些機器被視為數量不多的獨立、聯網的計算集群。
簡而言之,Google 的開發規模很大,速度可能是緩慢的,而且往往是笨拙的。但它是有效的。
Go 項目的目標是:消除 Google 軟件開發的緩慢和笨拙,從而使這個過程更富有成效和可擴展。這門語言是由編寫、閱讀、調試和維護大型軟件系統的人設計的,也是為他們設計的。
因此 Go 的目的不是為了研究編程語言的設計,而是為了改善其設計者及其同事的工作環境。
Go 更多的是關于軟件工程而不是編程語言研究。或者換個說法,它是為軟件工程服務的語言設計。
痛點
當 Go 發布時,有些人聲稱它缺少被認為是現代語言的必要條件的特定功能或方法。在缺乏這些設施的情況下,Go怎么可能有價值?
我們的答案是:Go 所擁有的特性可以解決那些使大規模軟件開發變得困難的問題。
這些問題包括:
- 構建速度緩慢。
- 不受控制的依賴關系。
- 每個程序員使用不同的語言子集。
- 對程序的理解不透徹(代碼可讀性差,文檔不全等)。
- 工作的重復性。
- 更新的成本。
- 版本偏移(version skew)。
- 編寫自動工具的難度。
- 跨語言的構建。
純粹一門語言的單個功能并不能解決這些問題,我們需要對軟件工程有一個更大的看法。因此在 Go 的設計中,我們試圖把重點放在這些問題的解決方案上。
總結
軟件工程指導了 Go 的設計。
與大多數通用編程語言相比,Go 的設計是為了解決我們在構建大型服務器軟件時接觸到的一系列軟件工程問題。這可能會使 Go 聽起來相當沉悶和工業化。
但事實上,整個設計過程中對清晰、簡單和可組合性的關注反而導致了一種高效、有趣的語言,許多程序員發現它的表現力和力量。
為此產生的 Go 特性包括:
- 清晰的依賴關系。
- 清晰的語法。
- 清晰的語義。
- 相對于繼承的組合。
- 編程模型提供的簡單性(垃圾收集、并發)。
- 簡單的工具(Go工具、gofmt、godoc、gofix)。
這就是為什么要開發 Go 的由來,以及為什么會產生如此的設計和特性的原因。
你學會了嗎?:)
參考
翻譯、修整《Go at Google: Language Design in the Service of Software Engineering》