重慶分公司,新征程啟航
為企業提供網站建設、域名注冊、服務器等服務
為企業提供網站建設、域名注冊、服務器等服務
簡而言之,所謂并發編程是指在一臺處理器上“同時”處理多個任務。
Golang語言中,并發使用的協程的機制,實現起來也是十分的方便,使用go關鍵字即可。
func main() { ... go fun(){ fmt.Println("Hi, Here is a goroutine.") }() ... }
什么是Goroutine
goroutine是Go并行設計的核心。goroutine說到底其實就是協程,它比線程更小,十幾個goroutine可能體現在底層就是五六個線程,Go語言內部幫你實現了這些goroutine之間的內存共享。
執行goroutine只需極少的棧內存(大概是4~5KB),當然會根據相應的數據伸縮。也正因為如此,可同時運行成千上萬個并發任務。goroutine比thread更易用、更高效、更輕便。
一般情況下,一個普通計算機跑幾十個線程就有點負載過大了,但是同樣的機器卻可以輕松地讓成百上千個goroutine進行資源競爭。
Goroutine的創建
只需在函數調?語句前添加 go 關鍵字,就可創建并發執?單元。開發人員無需了解任何執行細節,調度器會自動將其安排到合適的系統線程上執行。
在并發編程中,我們通常想將一個過程切分成幾塊,然后讓每個goroutine各自負責一塊工作,當一個程序啟動時,主函數在一個單獨的goroutine中運行,我們叫它main goroutine。新的goroutine會用go語句來創建。
而go語言的并發設計,讓我們很輕松就可以達成這一目的
以上就是golang并發編程是什么的詳細內容,更多請關注創新互聯成都網站設計公司其它相關文章!
另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。