Go語言為并發而生
Go語言為并發而生
如上所述,硬件制造商正在為處理器添加越來越多的內核以提高性能。所有數據中心都在這些處理器上運行,更重要的是,今天的應用程序使用多個微服務來維護數據庫連接,消息隊列和維護緩存。因此,開發的軟件和編程語言應該可以輕松地支持并發性,并且應該能夠隨著CPU核心數量的增加而可擴展。
但是,大多數現代編程語言(如Java,Python等)都來自90年代的單線程環境。雖然一些編程語言的框架在不斷地提高多核資源使用效率,例如 Java 的 Netty 等,但仍然需要開發人員花費大量的時間和精力搞懂這些框架的運行原理后才能熟練掌握。
Go于2009年發布,當時多核處理器已經上市。Go語言在多核并發上擁有原生的設計優勢,Go語言從底層原生支持并發,無須第三方庫、開發者的編程技巧和開發經驗。
很多公司,特別是中國的互聯網公司,即將或者已經完成了使用 Go 語言改造舊系統的過程。經過 Go 語言重構的系統能使用更少的硬件資源獲得更高的并發和I/O吞吐表現。充分挖掘硬件設備的潛力也滿足當前精細化運營的市場大環境。
Go語言的并發是基于 goroutine 的,goroutine 類似于線程,但并非線程。可以將 goroutine 理解為一種虛擬線程。Go 語言運行時會參與調度 goroutine,并將 goroutine 合理地分配到每個 CPU 中,最大限度地使用CPU性能。開啟一個goroutine的消耗非常小(大約2KB的內存),你可以輕松創建數百萬個goroutine。
goroutine的特點:
goroutine具有可增長的分段堆棧。這意味著它們只在需要時才會使用更多內存。
goroutine的啟動時間比線程快。
goroutine原生支持利用channel安全地進行通信。
goroutine共享數據結構時無需使用互斥鎖。
Go 任務調度
版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。