goroutine是Go并行設(shè)計(jì)的核心。goroutine說(shuō)到底其實(shí)就是協(xié)程,但是它比線程更小,幾十個(gè)goroutine可能體現(xiàn)在底層就是五六個(gè)線程,Go語(yǔ)言內(nèi)部幫你實(shí)現(xiàn)了這些goroutine之間的內(nèi)存共享。
執(zhí)行g(shù)oroutine只需極少的棧內(nèi)存(大概是4~5KB),當(dāng)然會(huì)根據(jù)相應(yīng)的數(shù)據(jù)伸縮。也正因?yàn)槿绱耍赏瑫r(shí)運(yùn)行成千上萬(wàn)個(gè)并發(fā)任務(wù)。
goroutine比thread更易用、更高效、更輕便。
一些高并發(fā)的處理方案基本都是使用協(xié)程,openresty也是利用lua語(yǔ)言的協(xié)程做到了高并發(fā)的處理能力,PHP的高性能框架Swoole目前也在使用PHP的協(xié)程。
協(xié)程更輕量,占用內(nèi)存更小,這是它能做到高并發(fā)的前提。
go web開發(fā)中怎么做到高并發(fā)的能力
學(xué)習(xí)go的HTTP代碼。先創(chuàng)建一個(gè)簡(jiǎn)單的web服務(wù)。
package main import ( "fmt" "log" "net/http" ) func response(w http.ResponseWriter, r *http.Request) { fmt.Fprintf(w, "Hello world!") //這個(gè)寫入到w的是輸出到客戶端的 } func main() { http.HandleFunc("/", response) err := http.ListenAndServe(":9000", nil) if err != nil { log.Fatal("ListenAndServe: ", err) } }
然后編譯
go build -o test_web.gobin ./test_web.gobin
然后訪問
curl 127.0.0.1:9000 Hello world!
以上就是golang能做高并發(fā)的原因的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注創(chuàng)新互聯(lián)其它相關(guān)文章!
本文標(biāo)題:golang為什么能做到高并發(fā)-創(chuàng)新互聯(lián)
文章網(wǎng)址:http://sd-ha.com/article20/deiijo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、自適應(yīng)網(wǎng)站、商城網(wǎng)站、用戶體驗(yàn)、搜索引擎優(yōu)化、網(wǎng)站策劃
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容