中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Golang協程調度器scheduler怎么使用

發布時間:2022-08-01 11:17:21 來源:億速云 閱讀:160 作者:iii 欄目:開發技術

這篇文章主要介紹“Golang協程調度器scheduler怎么使用”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Golang協程調度器scheduler怎么使用”文章能幫助大家解決問題。

1. 調度器scheduler的作用

我們都知道,在Go語言中,程序運行的最小單元是gorouines。

然而程序的運行最終都是要交給操作系統來執行的,以Java為例,Java中的一個線程對應的就是操作系統中的線程,以此來實現在操作系統中的運行。在Go中,gorouines比線程更輕量級,其與操作系統的線程也不是一一對應的關系,然而,最終我們想要執行程序,還是要借助操作系統的線程來完成,調度器scheduler的工作就是完成gorouines到操作系統線程的調度。

2. GMP模型

Golang協程調度器scheduler怎么使用

當我們運行go fun(){}時,會生成一個g,優先放置在創建他的p的本地隊列中,如果本地隊列已滿,那么會放置在全局隊列中。

g的運行需要借助p與m,p是執行器,只有獲得p的g才能執行,p的執行需要掛在m上,m對應的是操作系統中的線程,p的數量與CPU的核數相同。

goroutine運行所需要的上下文信息都是存放在g的數據結構當中的,所以g可以依靠任意的p或者m執行,而對于操作系統而言,其并不能看到p與g的調度過程,這些過程對于操作系統線程來說都是連續的,所以省去了線程上下文切換的開銷。

g的數據結構如下所示:

type g struct {
    stack       stack   // g自己的棧

    m            *m      // 執行當前g的m
    sched        gobuf   // 保存了g的現場,goroutine切換時通過它來恢復
    atomicstatus uint32  // g的狀態Gidle,Grunnable,Grunning,Gsyscall,Gwaiting,Gdead
    goid         int64
    schedlink    guintptr // 下一個g, g鏈表

    preempt       bool //搶占標記

    lockedm        muintptr // 鎖定的M,g中斷恢復指定M執行
    gopc           uintptr  // 創建該goroutine的指令地址
    startpc        uintptr  // goroutine 函數的指令地址
}

p的數據結構如下所示:

type p struct {
    id          int32
    status      uint32 // 狀態
    link        puintptr // 下一個P, P鏈表
    m           muintptr // 擁有這個P的M
    mcache      *mcache  

    // P本地runnable狀態的G隊列
    runqhead uint32
    runqtail uint32
    runq     [256]guintptr
    
    runnext guintptr // 一個比runq優先級更高的runnable G

    // 狀態為dead的G鏈表,在獲取G時會從這里面獲取
    gFree struct {
        gList
        n int32
    }

    gcBgMarkWorker       guintptr // (atomic)
    gcw gcWork

}

m的數據結構如下所示:

type m struct {
    g0      *g     // g0, 每個M都有自己獨有的g0

    curg          *g       // 當前正在運行的g
    p             puintptr // 當前用于的p
    nextp         puintptr // 當m被喚醒時,首先擁有這個p
    id            int64
    spinning      bool // 是否處于自旋

    park          note
    alllink       *m // on allm
    schedlink     muintptr // 下一個m, m鏈表
    mcache        *mcache  // 內存分配
    lockedg       guintptr // 和 G 的lockedm對應
    freelink      *m // on sched.freem

}

通過gmp模型,我們能解決gorouines到操作系統線程的映射問題,gorouines之間的切換是在用戶態完成的,在操作系統的視角來看,線程的上下文切換并不頻繁,因此就少了很多陷入內核的過程,所以有更好的并發效果。

3. 調度機制

1)work stealing機制

當一個p上的g執行完之后,他會嘗試從其他的p隊列中竊取g來執行,以減少操作系統線程的切換動作。

2)hand off機制

這個是針對m來說的,有的時候m可能因為g的信號調用而被操作系統阻塞,這個時候p就會掛載去另一個m繼續執行可以執行的g,當阻塞的m就緒之后,會給p發信號,召喚他回來繼續進行后續操作。

關于“Golang協程調度器scheduler怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

高州市| 独山县| 昌平区| 衡阳县| 崇文区| 朝阳县| 乌拉特前旗| 洛南县| 永仁县| 浦北县| 隆回县| 太湖县| 新干县| 报价| 色达县| 兰考县| 莲花县| 丰原市| 长治市| 富蕴县| 裕民县| 鄂温| 山西省| 金塔县| 洛宁县| 汕头市| 资兴市| 彩票| 吴桥县| 尼勒克县| 柳江县| 蕉岭县| 彭州市| 灵石县| 彭山县| 海南省| 定南县| 清远市| 仪征市| 新丰县| 普兰店市|