开启协程_「科普」什么是协程?
今天要講的這個(gè)東西說實(shí)話,我也是今天才知道,一個(gè)我們大多數(shù)人可能從來都沒用過的語法,哪就是傳說中的【協(xié)程】,英文表達(dá)是Coroutine。
可能你會說,攜程誰不知道啊,不就是哪個(gè)用來訂機(jī)票訂酒店的軟件么,這有什么好學(xué)的!這樣的話你就錯(cuò)了,此協(xié)程非彼攜程,可不要傻傻分不清楚嘍!
什么是進(jìn)程和線程
01 進(jìn)程是什么 ?
直白地講,進(jìn)程就是應(yīng)用程序的啟動實(shí)例。比如我們運(yùn)行一個(gè)游戲,打開一個(gè)軟件,就是開啟了一個(gè)進(jìn)程,進(jìn)程擁有代碼和打開的文件資源、數(shù)據(jù)資源、獨(dú)立的內(nèi)存空間。
02 線程又是什么 ?
線程從屬于進(jìn)程,是程序的實(shí)際執(zhí)行者。一個(gè)進(jìn)程至少包含一個(gè)主線程,也可以有更多的子線程,線程擁有自己的棧空間。
線程具有五種狀態(tài):
對操作系統(tǒng)來說,線程是最小的執(zhí)行單元,進(jìn)程是最小的資源管理單元。
無論進(jìn)程還是線程,都是由操作系統(tǒng)所管理的。
進(jìn)程和線程的痛點(diǎn)
線程之間是如何進(jìn)行協(xié)作的呢?
最經(jīng)典的例子就是生產(chǎn)者/消費(fèi)者模式:
若干個(gè)生產(chǎn)者線程向隊(duì)列中寫入數(shù)據(jù),若干個(gè)消費(fèi)者線程從隊(duì)列中消費(fèi)數(shù)據(jù)。
什么是協(xié)程
官方定義如下:
A coroutine is a function that can suspend its execution (yield) until the given given YieldInstruction finishes.用我蹩腳的英語來翻譯一下就是:
協(xié)程是一種可以暫停執(zhí)行過程的函數(shù),它可以中斷當(dāng)前的執(zhí)行過程直到下一個(gè) Yield 指令達(dá)成。我的理解是可以把它當(dāng)成為類似 于CPU 在多個(gè)進(jìn)程間切換,從而達(dá)到多個(gè)進(jìn)程同時(shí)執(zhí)行的效果。協(xié)程是一種比線程更加輕量級的存在,一個(gè)進(jìn)程可以擁有多個(gè)線程,一個(gè)線程也可以擁有多個(gè)協(xié)程。
學(xué)過計(jì)算機(jī)組成原理的都知道,當(dāng) CPU 在多個(gè)進(jìn)程間切換時(shí),那些后臺程序就會處于這種暫停用英文的 Suspend 或許更恰當(dāng))的狀態(tài),所以早年的電腦即使用一個(gè) CPU 也可以同時(shí)處理多個(gè)進(jìn)程任務(wù),這是一種“偽多線程”的技術(shù)。
除此之外比較重要的一點(diǎn)是,協(xié)程不是被操作系統(tǒng)內(nèi)核所管理,而完全是由程序所控制(也就是在用戶態(tài)執(zhí)行)。這樣帶來的好處就是性能得到了很大的提升,不會像線程那樣需要上下文切換來消耗資源,因此協(xié)程的開銷遠(yuǎn)遠(yuǎn)小于線程的開銷。
注意,這里要劃一個(gè)重點(diǎn),協(xié)程是一種“偽多線程”,始終記得這一點(diǎn),可以幫助我們來理解協(xié)程會這個(gè)概念。
協(xié)程函數(shù)的寫法
Java 語言并沒有對協(xié)程提供原生支持,所以用 Java 暫時(shí)還演示不了,但是有個(gè)開源框架基本模擬除了協(xié)程的功能,感興趣的朋友可以去看看源碼。。。
地址 :https://github.com/kilim/kilimGo 語言根據(jù)我查詢資料來看,對于協(xié)程的支持超乎我的想象,可以說是強(qiáng)大而簡潔,輕輕松松分分鐘創(chuàng)建成百上千個(gè)協(xié)程并發(fā)執(zhí)行。
func Add(x, y int) { z := x + y fmt.Println(z)}func main() { for i:=0; i<10; i++ { go Add(i, i) }}如上代碼,在一個(gè)函數(shù)調(diào)用前加上 go 關(guān)鍵字,這次調(diào)用就會在一個(gè)新的協(xié)程中并發(fā)執(zhí)行。當(dāng)被調(diào)用的函數(shù)返回時(shí),這個(gè)協(xié)程也自動結(jié)束。需要注意的是,如果這個(gè)函數(shù)有返回值,那么這個(gè)返回值會被丟棄。
Python 語言也可以通過 yield/send 的方式實(shí)現(xiàn)協(xié)程。在 python 3.5 以后,async/await 成為了更好的替代方案。
def consume():while True:# consumer 協(xié)程等待接收數(shù)據(jù)number = yieldprint("開始消費(fèi)總結(jié)
以上是生活随笔為你收集整理的开启协程_「科普」什么是协程?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 下载cx oracle 6,在Cento
- 下一篇: VS2005中GridView簡單應用