今天就跟大家聊聊有關go語言實現(xiàn)協(xié)程的方法,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供陸港網(wǎng)站建設、陸港做網(wǎng)站、陸港網(wǎng)站設計、陸港網(wǎng)站制作等企業(yè)網(wǎng)站建設、網(wǎng)頁設計與制作、陸港企業(yè)網(wǎng)站模板建站服務,10多年陸港做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡服務。
實現(xiàn)并發(fā)編程有進程,線程,IO多路復用的方式。(并發(fā)和并行我們這里不區(qū)分,如果CPU是多核的,可能在多個核同時進行,我們叫并行,如果是單核,需要排隊切換,我們叫并發(fā))
進程是計算機資源分配的最小單位,進程是對處理器資源,虛擬內(nèi)存(1)的抽象,而虛擬內(nèi)存是對主存資源和文件(2)的抽象,文件是對I/O設備的抽象。線程是計算機調(diào)度的最小單位,共享同個進程分配的計算機資源。
上面這些是在深入理解計算機系統(tǒng)說的。
總上所述,實際實現(xiàn)并發(fā)的是線程。首先,每個進程都有一個主線程,因為線程是調(diào)度的最小單位,你可以只有一個線程,但是你也可以創(chuàng)建多幾個線程,線程調(diào)度需要CPU來切換,需要內(nèi)核層的上下文切換,如果你跑了A線程,然后切到B線程,內(nèi)核調(diào)用開始,CPU需要對A線程的上下文保留,然后切到B線程,然后把控制權交給你的應用層調(diào)度。進程切換也需要內(nèi)核來切換,因為從C進程的主線程切換到D進程的主線程。
那么進程間要通訊呀,而且他們資源不共享,這個時候需要用IPC(Inter-Process Communication,進程間通信),常用的有信號量,共享內(nèi)存,套接字,實際百度上說有六種耶,而同個進程的多個線程共享資源,通訊起來比進程容易多了,現(xiàn)在很多Java等編程語言都有這種線程交互實現(xiàn)。
至于IO多路復用,其實就是維持一個隊列,然后讓一個線程或多個線程,去隊列里面拿任務去完成。為什么呢?因為線程的數(shù)量是有限的,而且線程間通訊需要點資源,內(nèi)核也要頻繁切換上下文。
一個線程的IO多路復用,典型的就是redis和Nodejs了,根本不需要切換上下文,一個線程走天下。而多個線程的IP多路復用,就是Golang協(xié)程的實現(xiàn)方式了,協(xié)程,自己管理線程,把線程控制到一定的數(shù)量,然后構造一個規(guī)則狀態(tài)機來調(diào)度任務。
看完上述內(nèi)容,你們對go語言實現(xiàn)協(xié)程的方法有進一步的了解嗎?如果還想了解更多相關內(nèi)容,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀。