亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Go語言Goroutinue和管道效率詳解

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

goroutinue基本介紹

進程和線程說明

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

并發(fā)和并行

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

同步和異步

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

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

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

go協(xié)程特點

  • 有獨立的棧空間
  • 共享程序堆空間
  • 調度由用戶控制
  • 協(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
	//設置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的調度模型

MPG

MPG運行狀態(tài)1

MPG運行狀態(tài)2

管道(channel)

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

  • 全局變量加鎖同步
  • channel

使用全局變量加鎖同步改進程序

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

全局變量加鎖同步缺陷

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

管道基本介紹

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

管道基本使用 聲明和定義

管道關閉和遍歷

關閉

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

遍歷

  • 在使用for--range遍歷時,如果channel沒有關閉,則回出現(xiàn)deadlock錯誤
  • 在使用for--range遍歷時,如果channel已經(jīng)關閉,則會正常遍歷數(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) //關閉管道
	for value := range intChan {
		fmt.Printf("%d\t",value) //10	20	30	
	}
}

管道注意事項

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

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

綜合案例

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和管道效率詳解的詳細內容,更多關于Go Goroutinue 管道效率的資料請關注腳本之家其它相關文章!

相關文章

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

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

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

    特殊字符的json序列化總結大全

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

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

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

    Golang import 導入包語法及一些特殊用法詳解

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

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

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

    一篇文章帶你搞懂Go語言標準庫Time

    在我們開發(fā)的過程中,每個項目都需要時間這一類的函數(shù),此時對time這個包的研究深度就顯得尤為重要,這篇文章主要給大家介紹了關于如何通過一篇文章帶你搞懂Go語言標準庫Time的相關資料,需要的朋友可以參考下
    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?結構體?方法集?接口實例詳解

    goalng?結構體?方法集?接口實例詳解

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

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

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

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

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

最新評論