欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Go語言Goroutinue和管道效率詳解

 更新時間:2022年09月23日 14:28:46   作者:山與路  
這篇文章主要為大家介紹了Go語言Goroutinue和管道效率使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

goroutinue基本介紹

進(jìn)程和線程說明

  • 進(jìn)程介紹程序在操作系統(tǒng)中的一次執(zhí)行過程,是系統(tǒng)進(jìn)行資源分配和調(diào)度的基本單位
  • 線程只是進(jìn)程的一個執(zhí)行實例或流程,是程序執(zhí)行的最小單元
  • 一個進(jìn)程可以有多個線程,但是一個線程只能對應(yīng)一個進(jìn)程
  • 同一個進(jìn)程中的多個線程可以并發(fā)執(zhí)行
  • 程序:運行起來的應(yīng)用程序就稱為進(jìn)程,也就是當(dāng)程序不運行的時候我們稱為程序,當(dāng)程序運行起來他就是一個進(jìn)程,通俗的理解就是不運行的時候是程序,運行起來就是進(jìn)程。程序只有一個,但是進(jìn)程有多個

并發(fā)和并行

  • 并發(fā):多個任務(wù)依次執(zhí)行,執(zhí)行過程中多個任務(wù)可以替換執(zhí)行,在某一個時刻是一個任務(wù)在執(zhí)行,但是在某個時間段內(nèi)是多個任務(wù)在執(zhí)行。
  • 并行:多個任務(wù)沒有順序,同時執(zhí)行,最終的執(zhí)行結(jié)果跟耗時最長的任務(wù)有關(guān)
  • 串行:多個任務(wù)依次執(zhí)行,上一個任務(wù)沒有完成時不能執(zhí)行后續(xù)的任務(wù),最明顯的同步執(zhí)行過程

同步和異步

  • 同步:描述的就是串行執(zhí)行過程,多個任務(wù)按照順序依次執(zhí)行的過程
  • 異步:描述的就是并發(fā)和并行的過程,就是多個任務(wù)在一個時間段內(nèi)同時執(zhí)行,每個任務(wù)都不會等待其他任務(wù)執(zhí)行完成后執(zhí)行

Go協(xié)程和Go主線程

Go主線程:一個Go線程上,可以起多個協(xié)程,協(xié)程是輕量級的線程

go協(xié)程特點

  • 有獨立的棧空間
  • 共享程序堆空間
  • 調(diào)度由用戶控制
  • 協(xié)程是輕量級的線程

goroutinue基本使用

實驗代碼

package main
import (
	"fmt"
	"runtime"
	"strconv"
	"time"
)
func main() {
	//編寫一個函數(shù),每隔1s輸出"hello,world"
	//要求主線程和gorutine同時執(zhí)行
	go test()
	//在主線程中,開啟一個goroutine,該協(xié)程每隔1s輸出"hello,world"
	for i:=1;i<=10 ; i++ {
		fmt.Println("main() hello world", strconv.Itoa(i))
		time.Sleep(time.Second)
	}
	//查詢Golang運行的cpu數(shù)
	fmt.Println(runtime.NumCPU()) //4
	//設(shè)置Golang運行的cpu數(shù)
	//runtime.GOMAXPROCS(runtime.NumCPU()-1)	//3
}
func test(){
	for i:=1;i<=10 ; i++ {
		fmt.Println("test() hello world",strconv.Itoa(i))
		time.Sleep(time.Second)
	}
}

效果圖

執(zhí)行流程圖

goroutinue的調(diào)度模型

MPG

MPG運行狀態(tài)1

MPG運行狀態(tài)2

管道(channel)

不同協(xié)程之間如何通訊

  • 全局變量加鎖同步
  • channel

使用全局變量加鎖同步改進(jìn)程序

  • 因為沒有對全局變量加鎖,因此會出現(xiàn)資源奪取問題,代碼會出現(xiàn)錯誤,提示concurrent map writes
  • 加入互斥鎖

全局變量加鎖同步缺陷

  • 主線程在等待所有g(shù)oroutine全部完成的時間很難確定
  • 如果主線程休眠時間長了,會加長等待時間,如果等待時間短了,可能還有g(shù)oroutine處于工作狀態(tài),這時也會隨著主線程的結(jié)束而結(jié)束
  • 不利于多個協(xié)程對全局變量的讀寫操作

管道基本介紹

  • 管道本質(zhì)介紹一個數(shù)據(jù)結(jié)構(gòu)-隊列
  • 數(shù)據(jù)是先進(jìn)先出
  • 線程安全,無需加鎖
  • 管道有類型

管道基本使用 聲明和定義

管道關(guān)閉和遍歷

關(guān)閉

使用內(nèi)置函數(shù)close可以關(guān)閉channel,關(guān)閉后,就不能寫入數(shù)據(jù),但可讀

遍歷

  • 在使用for--range遍歷時,如果channel沒有關(guān)閉,則回出現(xiàn)deadlock錯誤
  • 在使用for--range遍歷時,如果channel已經(jīng)關(guān)閉,則會正常遍歷數(shù)據(jù)

代碼

package main
import "fmt"
func main() {
	//定義管道
	var intChan chan int
	intChan =make(chan int,3)
	//寫入數(shù)據(jù)
	intChan<-10
	intChan<-20
	intChan<-30
	//遍歷
	close(intChan) //關(guān)閉管道
	for value := range intChan {
		fmt.Printf("%d\t",value) //10	20	30	
	}
}

管道注意事項

-`channel可以聲明為只讀,或者只寫性質(zhì)

  • 使用select可以解決從管道取數(shù)據(jù)的阻塞問題
  • goroutine中使用recover,解決協(xié)程中出現(xiàn)panic,導(dǎo)致程序崩潰問題

綜合案例

package main
import "fmt"
func main() {
	numChan := make(chan int, 2000)
	resChan := make(chan int, 2000)
	exitChan := make(chan bool, 8)
	go putNum(numChan) //存放數(shù)據(jù)
	//開啟八個協(xié)程
	for i := 0; i < 8; i++ {
		go add(numChan, resChan, exitChan)
	}
	go func() {
		for i:=0;i<8 ;i++  {
			<-exitChan
		}
		close(resChan)
	}()
	for i := 1; i <=2000 ; i++ {
		fmt.Printf("resChan[%d]=%d\n", i, <-resChan)
	}
}
func putNum(numChan chan int) {
	for i := 1; i <= 2000; i++ {
		numChan <- i
	}
	close(numChan)
}
func add(numChan chan int, resChan chan int, exitChan chan bool) {
	for {
		n,ok := <-numChan
		if !ok{
			break
		}
		res := 0
		for i := 1; i <= n; i++ {
			res += i
		}
		resChan <- res
	}
	exitChan<-true
}

以上就是Go語言Goroutinue和管道效率詳解的詳細(xì)內(nèi)容,更多關(guān)于Go Goroutinue 管道效率的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 簡化Go開發(fā)提高生產(chǎn)力的強大工具及使用詳解

    簡化Go開發(fā)提高生產(chǎn)力的強大工具及使用詳解

    作為?Go?開發(fā)人員,應(yīng)該都知道維持簡潔高效開發(fā)工作流程的重要性,為了提高工作效率和代碼質(zhì)量,簡化開發(fā)流程并自動執(zhí)行重復(fù)性任務(wù)至關(guān)重要,在本文中,我們將探討一些強大的工具和技術(shù),它們將簡化?Go?開發(fā)過程,助力您的編碼之旅
    2023-10-10
  • 特殊字符的json序列化總結(jié)大全

    特殊字符的json序列化總結(jié)大全

    這篇文章主要給大家介紹了關(guān)于特殊字符的json序列化的相關(guān)資料,通過示例代碼分別給大家介紹了關(guān)于python 、 rust 、 java 和golang對特殊字符的json序列化操作,需要的朋友可以參考借鑒,下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-09-09
  • Go語言簡介和環(huán)境配置

    Go語言簡介和環(huán)境配置

    Go語言保證了既能到達(dá)靜態(tài)編譯語言的安全和性能,又達(dá)到了動態(tài)語言開發(fā)速度和易維護(hù)性,有人形容Go語言:Go=?C?+?Python?,?說明Go語言既有C靜態(tài)語言程序的運行速度,又能達(dá)到Python動態(tài)語言的快速開發(fā),這篇文章主要介紹了Go介紹和環(huán)境配置,需要的朋友可以參考下
    2022-07-07
  • Golang import 導(dǎo)入包語法及一些特殊用法詳解

    Golang import 導(dǎo)入包語法及一些特殊用法詳解

    這篇文章主要介紹了Golang import 導(dǎo)入包語法及一些特殊用法,需要的朋友可以參考下
    2020-02-02
  • GOLANG使用Context管理關(guān)聯(lián)goroutine的方法

    GOLANG使用Context管理關(guān)聯(lián)goroutine的方法

    這篇文章主要介紹了GOLANG使用Context管理關(guān)聯(lián)goroutine的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • 一篇文章帶你搞懂Go語言標(biāo)準(zhǔn)庫Time

    一篇文章帶你搞懂Go語言標(biāo)準(zhǔn)庫Time

    在我們開發(fā)的過程中,每個項目都需要時間這一類的函數(shù),此時對time這個包的研究深度就顯得尤為重要,這篇文章主要給大家介紹了關(guān)于如何通過一篇文章帶你搞懂Go語言標(biāo)準(zhǔn)庫Time的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • Go語言之重要數(shù)組類型切片(slice)make,append函數(shù)解讀

    Go語言之重要數(shù)組類型切片(slice)make,append函數(shù)解讀

    這篇文章主要介紹了Go語言之重要數(shù)組類型切片(slice)make,append函數(shù)用法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • goalng?結(jié)構(gòu)體?方法集?接口實例詳解

    goalng?結(jié)構(gòu)體?方法集?接口實例詳解

    這篇文章主要為大家介紹了goalng?結(jié)構(gòu)體?方法集?接口實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • golang之?dāng)?shù)據(jù)校驗的實現(xiàn)代碼示例

    golang之?dāng)?shù)據(jù)校驗的實現(xiàn)代碼示例

    這篇文章主要介紹了golang之?dāng)?shù)據(jù)校檢的實現(xiàn)代碼示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • 創(chuàng)建Go工程化項目布局詳解

    創(chuàng)建Go工程化項目布局詳解

    這篇文章主要介紹了創(chuàng)建Go工程化項目布局詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09

最新評論