婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 詳解go語言的并發

詳解go語言的并發

熱門標簽:寧波語音外呼系統公司 地圖標注免費定制店 湛江crm外呼系統排名 不封卡外呼系統 上海極信防封電銷卡價格 鄭州智能語音電銷機器人價格 重慶慶云企業400電話到哪申請 宿遷便宜外呼系統代理商 仙桃400電話辦理

1、啟動go語言的協程

package main
 
import (
    "fmt"
    "runtime"
)
 
//runtime包
 
func main() {
    //runtime.Gosched() 用于讓出cpu時間片,讓出這段cpu的時間片,讓調度器重新分配資源
 
    //寫一個匿名函數
    s := "test"
    go func(s string) {
        for i :=0;i 2;i++ {
            fmt.Println(s)
        }
    }(s)
 
    for i :=0;i 2;i ++ {
        //如果代碼跑到這里,調度器會把cpu資源釋放出來,讓調度器重新分配cpu資源,可以分配到子協程,也可以重新分配到主協程
        runtime.Gosched()
        fmt.Println("123")
    }
}

2、runtime.Goexit()方法。立即終止當前的協程

package main
 
import (
    "fmt"
    "runtime"
    "time"
)
 
//runtime.Goexit()   立即終止當前的協程
func main() {
    go func() {
        defer fmt.Println("A.defter")
        func () {
            defer fmt.Println("B.defter")
            //立即終止當前的協程,函數會走defer流程
            runtime.Goexit()
            fmt.Println("B")
        }()
        fmt.Println("A")
    }()
    for {
        time.Sleep(2 * time.Second)
    }
}
 
//不加runtime.Goexit()的結果
//B
//B.defter
//A
//A.defter
 
//加runtime.Goexit()的結果
//B.defter
//A.defter

3、runtime.GOMAXPROCS()表示go使用幾個cpu執行代碼

package main
 
import (
    "fmt"
    "runtime"
)
 
func main() {
    //runtime.GOMAXPROCS() 表示讓go用幾個cpu做后面的事情
    n := runtime.GOMAXPROCS(4)
    fmt.Printf("%T--->%p---%d\n",n,n,n)
    for {
        go fmt.Print("0")
        fmt.Print(1)
    }
}

4、管道定義和創建管道

package main
 
import "fmt"
 
//go語言的協程運行在相同的地址空間,因此訪問共享內存必須做好同步,處理好線程安全問題
 
//go語言的協程之間的通信通過協程間通信來共享內存,而不是共享內存來通信
 
//channel是一個引用類型,用于多個協程間通信,內部實現了同步,確保并發安全
 
 
//通道一般是結合協程一起使用
 
 
//如果通道中沒有數據,后面你還去取數據,則會報錯
//fatal error: all goroutines are asleep - deadlock!
func main() {
    //test45_1 := make(chan int) //定義一個無緩沖的通道
 
    //無緩沖的通道是值在接受數據前沒有任何能力保存數據,只能有一個數據進入通道,進入通道后,該通道就會加鎖,一直到這個數據被取出,鎖才釋放
 
    //無緩沖的通道有可能阻塞,如果我發送一個數據到通道,但是沒有協程來取數據,則對于第一個協程就被阻塞
 
    //test45_2 := make(chan int,10)  //定義 一個有緩沖的通道
 
 
    //有緩沖的通道就是通道可以存儲指定數量的數據,數據在里面也是有順序的,但是如果緩沖的數量滿了,這個通道也會是阻塞的
 
    //
    //test45_1 - 10   //發送數據到通道
    //- test45_1      //接受通道中的數據,并丟棄
    //x := -test45_1 //從通道取值并賦值給x
    //x,ok := -test45_1  //ok檢查通道是否關閉或者是否為空
 
 
    //1、創建一個存放int類型的通道
    test45_1 := make(chan int)
 
    go func() {
        defer fmt.Println("子協程結束")
        fmt.Println("子協程正在運行")
 
        test45_1 - 111
    }()
    //- test45_1
    //主協程從通道中取數據
    x := - test45_1
    fmt.Println(x)
    fmt.Println("主協程結束")
}

5、管道的緩沖

package main
 
import (
    "fmt"
    "time"
)
 
func main() {
    //無緩沖的通道,長度為0就可以了,有緩沖的通道,這里設置為非0就可以了
    test46_1 := make(chan int,0)
 
    //%P是打印內存地址,%T是打印變量的類型
    //fmt.Printf("長度:%d--->容量:%d---->%P----%T",len(test46_1),cap(test46_1),test46_1,test46_1)
 
    go func() {
        defer fmt.Printf("子協程結束")
 
        for i :=0;i  3;i ++ {
            fmt.Println("子協程插入數據")
            test46_1 - i
            //fmt.Printf("長度:%d--->容量:%d---->%P----%T",len(test46_1),cap(test46_1),test46_1,test46_1)
 
        }
 
    }()
 
    time.Sleep(2 * time.Second)
    for j :=0;j 3;j++ {
        fmt.Println("主協程取數據")
        num := - test46_1
        fmt.Println(num)
    }
}

6、關閉管道和接受關閉管道的信號

package main
 
import "fmt"
 
//close()方法,關閉通道的意思
 
func main() {
    test47_1 := make(chan int,4)
 
    go func() {
        for i :=0;i  10;i ++ {
            test47_1 - i
        }
        //這個的意思關閉通道test47_1
        close(test47_1)
    }()
 
    //for的寫法,遍歷通道
    //for {
    //  //子協程關閉了通道,這里ok就可以接收到,這里就可以走到bread流程,ok這個參數表示通道是否關閉
    //  if data,ok := - test47_1;ok {
    //      fmt.Println(data)
    //  }else {
    //      break
    //  }
    //}
 
    //range的寫法,遍歷通道
    for data := range test47_1 {
        fmt.Println(data)
    }
    fmt.Println("主協程結束")
}

7、只讀管道和只寫管道和生產者和消費者模型

package main
 
import (
    "fmt"
    "time"
)
 
//默認情況下,管道是雙向的,既可以寫入數據,也可以讀出數據。go也可以定義單方向的管道,也就是說只發送數據,或者只寫入數據
 
//可以把雙向的管道轉換為單向的管道,但是不能把單向的管道轉換為雙向的管道
 
//單方向的管道
 
func producter(out chan - int)  {
    defer close(out)
    for i := 0;i  10;i++ {
        out - i
    }
 
}
 
func consumer(int -chan int){
    for num := range int {
        fmt.Println(num)
    }
}
func main() {
 
    //1、定義管道
    //定義一個正常的管道
    //var test48_1 chan int
 
    //定義一個單向的只寫的管道
    //var test48_2 chan - float32
 
    //定義一個單向的只讀的管道
    //var test48_3 - chan int
 
    //2、轉換管道
 
    //轉換正常管道為只寫或者只讀的管道
    //定義一個正常的管道
    //test48_4 := make(chan int,3)
 
    //把一個正常的管道轉換為一個只寫的管道
    //var write_only chan - int = test48_4
 
    //把一個正常的管道轉換為一個只讀的管道
    //var read_only - chan int = test48_4
 
 
 
    test48_5 := make(chan int,4)
 
    //啟動生產者
    go producter(test48_5)
 
    //啟動消費者
    consumer(test48_5)
 
    time.Sleep(10 * time.Millisecond)
    fmt.Println("down")
 
}

8、Timer定時器

package main
 
import (
    "fmt"
    "time"
)
 
//定時器
 
//time.NewTimer()。時間到了,只執行一次
//time.NewTicker(),周期性的執行
 
func main() {
    //1、創建一個定時器,2s后定時器會將一個時間保存到一個C
    test49_1 := time.NewTimer(2 * time.Second)
 
    //打印系統當前的時間
 
    t1 := time.Now()
 
    fmt.Printf("t1----->%v\n",t1)
 
    //從管道中取出C打印
 
    t2 := - test49_1.C
    fmt.Printf("t2----->%v\n",t2)
 
 
 
    //2、證明timer只執行一次
    //test49_2 := time.NewTimer(4 * time.Second)
    //
    //for {
    //  c := - test49_2.C
    //  fmt.Println(c)
    //}
 
    //3、通過timer實現一個延時的功能
 
    //方式1
    //time.Sleep(2 * time.Second)
 
    //方式2
    //test49_3 := time.NewTimer(2 * time.Second)
 
    //方式3
 
    //-time.After(2 *time.Second)
 
    //4、停止定時器
    test49_4 := time.NewTimer(4 * time.Second)
    //子協程
    go func() {
        //這個意思是3s后才能取出來數據
        - test49_4.C
 
        fmt.Println("定時器時間到了")
    }()
 
    //關閉定時器
    stop := test49_4.Stop()
    if stop {
        fmt.Println("定時器已經關閉")
    }
 
    //5、重置定時器
    test49_5 := time.NewTimer(4 * time.Second)
    //重置定時器為1s
    test49_5.Reset(1 * time.Second)
 
    for {
 
    }
    }

9、ticker定時器和關閉ticker定時器

package main
 
import (
    "fmt"
    "time"
)
 
//time.NewTicker(),定時器,響應多次
 
func main() {
    //創建一個定時器,間隔1s
    test50_1 := time.NewTicker(time.Second)
    i := 0
    go func() {
        for {
            c := - test50_1.C
            fmt.Println(c)
            i ++
            fmt.Println(i)
        }
        }()
 
 
    for {
 
    }
}

10、select語句

package main
 
import (
    "fmt"
)
 
//go語言提供select關鍵字,用來監聽通道上的數據流動,語法和switch類似,區別是select必須要求每個case語句里必須是一個IO操作
 
//如果都能匹配到,則隨機選擇一個通道去跑,select是比較隨便的
 
func main() {
    //test51_1 := make(chan int,3)
    //select {
    //case - test51_1:
    //  fmt.Println("jja")
    ////如果從通道中可以讀出數據,則執行這里
    //case test51_1 - 1:
    //  fmt.Println("aa")
    ////如果通道中北寫入數據,則執行號這里
    //default:
    //  fmt.Println("hah")
    ////如果上面都沒成功,則執行這里
    //}
 
 
    test51_1 := make(chan int,1)
    test51_2 := make(chan string,1)
 
    go func() {
        //time.Sleep(2 * time.Second)
        test51_1 - 1
 
    }()
    go func() {
        test51_2 - "Hello World"
    }()
 
    select {
    case Value1:= - test51_1:
        fmt.Println(Value1)
    case Value2 := - test51_2:
        fmt.Println(Value2)
    }
    fmt.Println("結束")
 
}

11、協程同步鎖

package main
 
import (
    "fmt"
    "sync"
    "time"
)
 
//go語言的協程同步鎖,解決并發安全問題
 
 
//取錢的例子
 
type Account struct {
    money int
    flag sync.Mutex
}
 
func Check(a *Account)  {
    time.Sleep(1 * time.Second)
}
 
func (a *Account)SetAccount(n int)  {
    a.money = n
}
 
func (a *Account)GetAccount() (n int) {
    return a.money
}
 
func (a *Account) buy1(n int)  {
    a.flag.Lock()
    if a.money > n {
        Check(a)
        a.money -= n
    }
    a.flag.Unlock()
    fmt.Println(a.money)
}
 
 
func (a *Account) buy2(n int)  {
    a.flag.Lock()
    if a.money > n {
        Check(a)
        a.money -= n
    }
    a.flag.Unlock()
    fmt.Println(a.money)
}
 
func main() {
    var test52_1 Account
    test52_1.SetAccount(10)
 
    go test52_1.buy1(5)
    go test52_1.buy2(6)
    for {
 
    }
}

12、wait

我們自己實現wait

package main
 
import "fmt"
//Add() 計數加1
//Done() 計數減1
//Wait() 主函數調用
func main() {
    test53_1 := make(chan int,2)
    count := 2
    go func() {
        fmt.Println("子協程1")
        test53_1 - 1
    }()
    go func() {
        fmt.Println("子協程2")
        test53_1 - 2
    }()
 
    for range test53_1 {
        count --
        if count == 0 {
            fmt.Println("所有的子協程都已經結束")
            close(test53_1)
        }
    }
}

go語言為我們實現wait

package main
 
import (
    "fmt"
    "sync"
)
//Add() 計數加1
//Done() 計數減1
//Wait() 主函數調用
func main() {
 
    var wait_group sync.WaitGroup
 
    //這里就是子協程的個數
    wait_group.Add(2)
    //test54_1 := make(chan int,2)
 
    go func() {
        fmt.Println("子協程1")
        wait_group.Done()
    }()
    go func() {
        fmt.Println("子協程2")
        wait_group.Done()
    }()
 
 
    wait_group.Wait()
    //close(test53_1)
    fmt.Println("所有的子協程都結束")
 
}

以上就是詳解go語言的并發的詳細內容,更多關于go語言的并發的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • 快速解決Golang Map 并發讀寫安全的問題
  • 淺談golang并發操作變量安全的問題
  • golang高并發限流操作 ping / telnet
  • golang gin 框架 異步同步 goroutine 并發操作
  • Golang 實現分片讀取http超大文件流和并發控制
  • golang-gin-mgo高并發服務器搭建教程
  • 詳解Go多協程并發環境下的錯誤處理
  • Django高并發負載均衡實現原理詳解
  • golang通過context控制并發的應用場景實現
  • 一百行Golang代碼實現簡單并發聊天室
  • 基于Django的樂觀鎖與悲觀鎖解決訂單并發問題詳解

標簽:儋州 物業服務 遼寧 電子產品 安康 西雙版納 青海 海南

巨人網絡通訊聲明:本文標題《詳解go語言的并發》,本文關鍵詞  詳解,語言,的,并發,詳解,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解go語言的并發》相關的同類信息!
  • 本頁收集關于詳解go語言的并發的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    色视频成人在线观看免| 欧美色图第一页| 自拍偷拍亚洲综合| 中文字幕亚洲成人| 日日骚欧美日韩| 成人精品gif动图一区| 欧美精选一区二区| 中文字幕一区二区日韩精品绯色| 蜜桃精品在线观看| 91精品1区2区| 国产精品久久久久久福利一牛影视| 久久精品一区二区三区不卡牛牛 | 亚洲国产成人tv| 中文字幕一区二区三区四区| 国产一区二区三区四| 777xxx欧美| 亚洲一区二区三区四区在线免费观看 | 欧美在线观看一二区| 亚洲欧洲日本在线| 国模少妇一区二区三区| 精品国产一区二区三区四区四| 中文字幕一区视频| 色婷婷久久久综合中文字幕| 亚洲精品美国一| 在线精品视频一区二区| 亚洲精品国产一区二区精华液| 91一区在线观看| 国产精品盗摄一区二区三区| 成人精品视频网站| 亚洲女人****多毛耸耸8| 日本福利一区二区| 日日摸夜夜添夜夜添亚洲女人| 制服丝袜亚洲网站| 国产美女精品人人做人人爽 | 欧美韩国日本一区| thepron国产精品| 一区二区成人在线| 91精品国产色综合久久ai换脸 | 欧美极品美女视频| 丁香另类激情小说| 亚洲一区二区偷拍精品| 91精品福利在线| 午夜精品久久久久久久99樱桃| 欧美人妖巨大在线| 韩国精品主播一区二区在线观看 | 一区在线观看视频| 国产精品你懂的在线欣赏| 免费观看久久久4p| 国产精品系列在线| 欧美久久久影院| 国产一区二区三区高清播放| 久久精品日韩一区二区三区| 91丨九色丨国产丨porny| 视频一区在线播放| 久久久三级国产网站| 风间由美一区二区av101 | 日本在线不卡视频一二三区| 欧美顶级少妇做爰| 麻豆一区二区99久久久久| 欧美日韩一卡二卡三卡| 亚洲成人精品一区| 欧美国产精品中文字幕| 欧美精品在线一区二区三区| 欧美国产欧美综合| 欧美成va人片在线观看| 欧美视频一区二区三区| 一区二区三区四区精品在线视频| 欧美日韩国产片| 99久久免费精品| 国产精品自拍av| 日韩精品国产精品| 天天av天天翘天天综合网| 亚洲综合视频在线观看| 亚洲人吸女人奶水| 中文字幕一区三区| 日韩一区在线免费观看| 亚洲私人黄色宅男| 亚洲精品午夜久久久| 一区二区三区中文在线| 一区二区三区中文免费| 亚洲成人精品影院| 麻豆91精品视频| 日韩电影一区二区三区四区| 亚洲一区二区欧美日韩| 综合久久给合久久狠狠狠97色| 日韩欧美国产不卡| 日韩一级视频免费观看在线| 91精品国产综合久久精品app| 91精品欧美一区二区三区综合在| 欧美日韩中文字幕一区| 欧美专区在线观看一区| 91久久免费观看| 欧美日韩国产大片| 日韩视频免费直播| 精品乱人伦小说| 国产精品二三区| 天天综合色天天| 国产一区中文字幕| caoporn国产精品| 亚洲裸体xxx| 丝袜美腿亚洲综合| 蜜桃精品视频在线观看| 欧美一区二区久久久| 欧美亚男人的天堂| 日韩三级精品电影久久久| 精品国一区二区三区| 亚洲夂夂婷婷色拍ww47| 婷婷综合另类小说色区| 国产麻豆一精品一av一免费| 欧美性色aⅴ视频一区日韩精品| 国产亲近乱来精品视频| 日韩激情av在线| 色欧美乱欧美15图片| 久久久久国产免费免费| 日日摸夜夜添夜夜添精品视频| zzijzzij亚洲日本少妇熟睡| 精品国产乱码久久久久久影片| 中文字幕av资源一区| 琪琪一区二区三区| 欧美日韩一级视频| 中文字幕精品一区二区三区精品| 日本一不卡视频| 色8久久精品久久久久久蜜| 中文在线一区二区| 激情图区综合网| 日韩一级精品视频在线观看| 亚洲国产精品久久艾草纯爱| 91丨九色丨尤物| 国产精品女同互慰在线看| 蜜臀va亚洲va欧美va天堂| 91日韩在线专区| 国产精品免费网站在线观看| 麻豆精品一区二区| 欧美电影在线免费观看| 亚洲影院在线观看| 日本道免费精品一区二区三区| 亚洲美女一区二区三区| 国产精品一二三四| 91精品国产综合久久婷婷香蕉| 亚洲另类中文字| 国产99一区视频免费| 日韩一级黄色片| 成人免费毛片嘿嘿连载视频| 91影视在线播放| 精品视频在线免费观看| 五月天欧美精品| 天天色天天操综合| 日本午夜一区二区| 欧美tickle裸体挠脚心vk| 欧美久久高跟鞋激| 精品99一区二区三区| 国产午夜一区二区三区| 91精品国产综合久久久久久漫画| 欧美日韩午夜影院| 欧美日韩在线观看一区二区| 欧美日韩精品一区二区三区| 欧美高清一级片在线| 亚洲成人综合视频| 秋霞成人午夜伦在线观看| 日韩av高清在线观看| 欧美a级一区二区| 欧美成人猛片aaaaaaa| 肉色丝袜一区二区| 国产成人综合在线| 国产欧美视频一区二区| 91福利社在线观看| 丝袜美腿一区二区三区| 老司机精品视频导航| 国产日产精品1区| 日韩激情视频在线观看| 成人18视频日本| 日韩制服丝袜av| 99久久亚洲一区二区三区青草| 欧美高清激情brazzers| 国产日产欧产精品推荐色| 亚洲午夜av在线| 成人国产精品免费| 久久精品国产在热久久| 在线视频一区二区免费| 国产三级一区二区三区| 国产三级精品三级| 91精品国产综合久久香蕉麻豆| 中文字幕一区在线观看视频| 老色鬼精品视频在线观看播放| 美日韩一级片在线观看| 亚洲欧美日韩在线| 成人午夜视频在线| 久久综合成人精品亚洲另类欧美| 亚洲精品在线一区二区| 欧美猛男gaygay网站| 国产精品精品国产色婷婷| 蜜桃精品在线观看| 欧美一区二区三级| 欧美一卡二卡三卡四卡| 一区二区三区国产精华| 国产精品理伦片| 成人精品gif动图一区| 国产无遮挡一区二区三区毛片日本| 日韩高清一区在线| 欧美一级免费大片|