硬件制造商正在為處理器添加越來越多的內核以提高性能。所有數據中心都在這些處理器上運行,更重要的是,今天的應用程序使用多個微服務來維護數據庫連接,消息隊列和維護緩存。因此,開發的軟件和編程語言應該可以輕松地支持并發性,并且應該能夠隨著CPU核心數量的增加而可擴展。
但是,大多數現代編程語言(如Java,Python等)都來自90年代的單線程環境。雖然一些編程語言的框架在不斷地提高多核資源使用效率,例如 Java 的 Netty 等,但仍然需要開發人員花費大量的時間和精力搞懂這些框架的運行原理后才能熟練掌握。
go語言(或 Golang)是Google開發的開源編程語言,誕生于2006年1月2日下午15點4分5秒,于2009年11月開源,2012年發布go穩定版。Go語言在多核并發上擁有原生的設計優勢,Go語言從底層原生支持并發,無須第三方庫、開發者的編程技巧和開發經驗。
go是非常年輕的一門語言,它的主要目標是“兼具 Python 等動態語言的開發速度和 C/C++ 等編譯型語言的性能與安全性”
很多公司,特別是中國的互聯網公司,即將或者已經完成了使用 Go 語言改造舊系統的過程。經過 Go 語言重構的系統能使用更少的硬件資源獲得更高的并發和 I/O 吞吐表現。充分挖掘硬件設備的潛力也滿足當前精細化運營的市場大環境。
Go語言的并發是基于 `goroutine` 的,`goroutine` 類似于線程,但并非線程。可以將 goroutine 理解為一種虛擬線程。Go 語言運行時會參與調度 `goroutine`,并將 `goroutine` 合理地分配到每個 CPU 中,最大限度地使用CPU性能。開啟一個 `goroutine` 的消耗非常小(大約2KB的內存),你可以輕松創建數百萬個 `goroutine` 。
`goroutine` 的特點:
1. 可增長的分段堆棧。這意味著它們只在需要時才會使用更多內存。
2. 啟動時間比線程快。
3. 原生支持利用channel安全地進行通信。
4. 共享數據結構時無需使用互斥鎖。
- Golang簡介
- 開發環境
- Golang安裝
- 編輯器及快捷鍵
- vscode插件
- 第一個程序
- 基礎數據類型
- 變量及匿名變量
- 常量與iota
- 整型與浮點型
- 復數與布爾值
- 字符串
- 運算符
- 算術運算符
- 關系運算符
- 邏輯運算符
- 位運算符
- 賦值運算符
- 流程控制語句
- 獲取用戶輸入
- if分支語句
- for循環語句
- switch語句
- break_continue_goto語法
- 高階數據類型
- pointer指針
- array數組
- slice切片
- slice切片擴展
- map映射
- 函數
- 函數定義和調用
- 函數參數
- 函數返回值
- 作用域
- 函數形參傳遞
- 匿名函數
- 高階函數
- 閉包
- defer語句
- 內置函數
- fmt
- strconv
- strings
- time
- os
- io
- 文件操作
- 編碼
- 字符與字節
- 字符串
- 讀寫文件
- 結構體
- 類型別名和自定義類型
- 結構體聲明
- 結構體實例化
- 模擬構造函數
- 方法接收器
- 匿名字段
- 嵌套與繼承
- 序列化
- 接口
- 接口類型
- 值接收者和指針接收者
- 類型與接口對應關系
- 空接口
- 接口值
- 類型斷言
- 并發編程
- 基本概念
- goroutine
- channel
- select
- 并發安全
- 練習題
- 第三方庫
- Survey
- cobra