站長資訊網(wǎng)
        最全最豐富的資訊網(wǎng)站

        golang有進(jìn)程嗎

        golang有進(jìn)程。進(jìn)程就是程序在操作系統(tǒng)中的一次執(zhí)行過程,是由系統(tǒng)進(jìn)行資源分配和調(diào)度的基本單位;進(jìn)程是一個動態(tài)概念,是程序在執(zhí)行過程中分配和管理資源的基本單位,每一個進(jìn)程都有一個自己的地址空間。go語言支持多進(jìn)程,它線程模型是MPG模型,整體上Go程與內(nèi)核線程是多對多對應(yīng)的。

        golang有進(jìn)程嗎

        本教程操作環(huán)境:windows7系統(tǒng)、GO 1.18版本、Dell G3電腦。

        一、關(guān)于進(jìn)程和線程

        1. 進(jìn)程(Process)

        進(jìn)程就是程序在操作系統(tǒng)中的一次執(zhí)行過程,是由系統(tǒng)進(jìn)行資源分配和調(diào)度的基本單位,進(jìn)程是一個動態(tài)概念,是程序在執(zhí)行過程中分配和管理資源的基本單位,每一個進(jìn)程都有一個自己的地址空間。一個進(jìn)程至少有5種基本狀態(tài):初始態(tài)、執(zhí)行態(tài)、等待狀態(tài)、就緒狀態(tài)、終止?fàn)顟B(tài)。

        通俗講:進(jìn)程就是一個正在執(zhí)行的程序。

        2. 線程

        線程是進(jìn)程的一個執(zhí)行實(shí)例,是程序執(zhí)行的最小單元,它是比進(jìn)程更小的能獨(dú)立運(yùn)行的基本單位。

        通俗講:一個進(jìn)程可以創(chuàng)建多個線程,同一個進(jìn)程中的多個線程可以并發(fā)執(zhí)行,一個程序要運(yùn)行的話至少有一個進(jìn)程。

        golang有進(jìn)程嗎

        golang有進(jìn)程嗎

        二、關(guān)于并發(fā)和并行

        1. 并發(fā)

        多個線程同時競爭一個位置,競爭到的才可以執(zhí)行,每一個時間段只有一個線程在執(zhí)行。

        golang有進(jìn)程嗎

        2. 并行

        多個線程可以同時執(zhí)行,每一個時間段,可以有多個線程同時執(zhí)行。

        golang有進(jìn)程嗎

        3. 通俗講

        多線程程序在單核cpu上運(yùn)行就是并發(fā),在多核cpu上運(yùn)行就是并行。如果線程數(shù)大于cpu核數(shù),則多線程程序在多個cpu上既有并發(fā)也有并行。

        三、goroutine協(xié)程以及主線程

        1. 主線程

        可以理解為線程或進(jìn)程,在一個golang程序的主線程上可以啟用多個協(xié)程。golang中多協(xié)程可以實(shí)現(xiàn)并發(fā)或者并行。

        2. 協(xié)程

        可以理解為用戶級別的線程,這是對內(nèi)核透明的,也就是系統(tǒng)并不知道有協(xié)程的存在,是完全由用戶自己的程序進(jìn)行調(diào)度的。golang的一大特色就是從語言方面原生支持協(xié)程,在函數(shù)或方法前面加一個go關(guān)鍵詞就可以創(chuàng)建一個協(xié)程。可以說golang中的協(xié)程就是goroutine。

        golang有進(jìn)程嗎

        Golang 中的多協(xié)程有點(diǎn)類似其他語言中的多線程。

        3. 多協(xié)程和多線程

        Golang 中每個 goroutine (協(xié)程) 默認(rèn)占用內(nèi)存遠(yuǎn)比 Java 、C 的線程少。 OS 線程(操作系統(tǒng)線程)一般都有固定的棧內(nèi)存(通常為 2MB 左右),一個 goroutine (協(xié)程) 占用內(nèi)存非常小,只有 2KB 左右,多協(xié)程 goroutine 切換調(diào)度開銷方面遠(yuǎn)比線程要少。 這也是為什么越來越多的大公司使用 Golang 的原因之一。

        四、go關(guān)鍵詞實(shí)操

        1. 順序執(zhí)行

        package main  import "fmt"  func test() { 	for i := 0; i < 5; i++ { 		fmt.Println("test執(zhí)行", i) 	} }  func main() {     // 正常順序執(zhí)行 	test() 	for i := 0; i < 5; i++ { 		fmt.Println("main執(zhí)行", i) 	} 	/* 		test執(zhí)行 0 		test執(zhí)行 1 		test執(zhí)行 2 		test執(zhí)行 3 		test執(zhí)行 4 		main執(zhí)行 0 		main執(zhí)行 1 		main執(zhí)行 2 		main執(zhí)行 3 		main執(zhí)行 4 	*/ }
        登錄后復(fù)制

        2. 加入go

        package main  import "fmt"  func test() { 	for i := 0; i < 5; i++ { 		fmt.Println("test執(zhí)行", i) 	} }  func main() {     // 加入goroutine后 	go test() 	for i := 0; i < 5; i++ { 		fmt.Println("main執(zhí)行", i) 	} 	/* 		main執(zhí)行 0 		main執(zhí)行 1 		main執(zhí)行 2 		main執(zhí)行 3 		main執(zhí)行 4 		主線程執(zhí)行完畢后,并沒有等待協(xié)程的執(zhí)行 	*/ }
        登錄后復(fù)制

        3. 加入時間

        package main  import (     "fmt"     "time" )  // 加入時間 func test1() { 	for i := 0; i < 5; i++ { 		fmt.Println("test執(zhí)行", i) 		time.Sleep(time.Millisecond * 100) 	} }  func main() {     // 加入sleep之后再執(zhí)行 	go test1() 	for i := 0; i < 5; i++ { 		fmt.Println("main執(zhí)行", i) 		time.Sleep(time.Millisecond * 100) 	} 	/* 		main執(zhí)行 0 		test執(zhí)行 0 		test執(zhí)行 1 		main執(zhí)行 1 		main執(zhí)行 2 		test執(zhí)行 2 		main執(zhí)行 3 		test執(zhí)行 3 		test執(zhí)行 4 		main執(zhí)行 4 		加入相同的睡眠時間后,執(zhí)行的順序不一定,但少量數(shù)據(jù)來看均會執(zhí)行完畢 	*/ }
        登錄后復(fù)制

        4. 主線程執(zhí)行快的情況

        package main  import (     "fmt"     "time" )  func test1() { 	for i := 0; i < 5; i++ { 		fmt.Println("test執(zhí)行", i) 		time.Sleep(time.Millisecond * 100) 	} }  func main() {     // 如果主線程執(zhí)行的快會出現(xiàn)什么情況? 	go test1() 	for i := 0; i < 5; i++ { 		fmt.Println("main執(zhí)行", i) 		time.Sleep(time.Millisecond * 20) 	} 	/* 		main執(zhí)行 0 		test執(zhí)行 0 		main執(zhí)行 1 		main執(zhí)行 2 		main執(zhí)行 3 		main執(zhí)行 4 		test執(zhí)行 1 		那么他將不會等待協(xié)程執(zhí)行,就會退出執(zhí)行。 	*/ }
        登錄后復(fù)制

        5. sync.WaitGroup解決不等待

        package main  import (     "fmt"     "time"     "sync" )  var wg sync.WiatGroup  func test2() { 	for i := 0; i < 5; i++ { 		fmt.Println("test執(zhí)行", i) 		time.Sleep(time.Millisecond * 100) 	} 	wg.Done() }  func main() {     // sync.WaitGroup 完美解決,以后在項目中也會經(jīng)常使用 	wg.Add(1) 	go test2() 	for i := 0; i < 5; i++ { 		fmt.Println("main執(zhí)行", i) 		time.Sleep(time.Millisecond * 20) 	} 	wg.Wait() 	/* 		main執(zhí)行 0 		test執(zhí)行 0 		main執(zhí)行 1 		main執(zhí)行 2 		main執(zhí)行 3 		main執(zhí)行 4 		test執(zhí)行 1 		test執(zhí)行 2 		test執(zhí)行 3 		test執(zhí)行 4 		這樣就可以解決主線程執(zhí)行完畢后,不等待等待協(xié)程執(zhí)行完畢就退出的問題。 	*/ }
        登錄后復(fù)制

        6. 多協(xié)程并發(fā)并行執(zhí)行

        package main  import (     "fmt"     "time"     "sync" )  func hello(num int) { 	defer wg.Done() 	for i := 0; i < 5; i++ { 		fmt.Printf("第%v個協(xié)程執(zhí)行--%vn", num, i) 	}  }  func main() {     // 多協(xié)程并發(fā)執(zhí)行 	for i := 0; i < 3; i++ { 		wg.Add(1) 		go hello(i) 	} 	wg.Wait() 	/* 		第2個協(xié)程執(zhí)行--0 		第2個協(xié)程執(zhí)行--1 		第2個協(xié)程執(zhí)行--2 		第2個協(xié)程執(zhí)行--3 		第2個協(xié)程執(zhí)行--4 		第0個協(xié)程執(zhí)行--0 		第0個協(xié)程執(zhí)行--1 		第0個協(xié)程執(zhí)行--2 		第0個協(xié)程執(zhí)行--3 		第0個協(xié)程執(zhí)行--4 		第1個協(xié)程執(zhí)行--0 		第1個協(xié)程執(zhí)行--1 		第1個協(xié)程執(zhí)行--2 		第1個協(xié)程執(zhí)行--3 		第1個協(xié)程執(zhí)行--4 	*/ }
        登錄后復(fù)制

        五、設(shè)置golang運(yùn)行時占用的cpu核數(shù)量(不是很重要)

        package main  import (     "fmt"     "runtime" )  func main() {     // 設(shè)置程序占用幾個cpu進(jìn)行執(zhí)行,默認(rèn)是全部 	// 獲取計算機(jī)cpu個數(shù) 	cpuNum := runtime.NumCPU() 	fmt.Println(cpuNum) // 6 我本機(jī)電腦是6核cpu  	// 設(shè)置占用cpu個數(shù) 	runtime.GOMAXPROCS(2) 	fmt.Println("ok") }
        登錄后復(fù)制

        贊(0)
        分享到: 更多 (0)
        網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
        主站蜘蛛池模板: 亚洲AV永久无码精品水牛影视| 国产亚洲欧洲精品| 国产精品无套内射迪丽热巴| 久久国产热这里只有精品| 99在线精品一区二区三区| 亚洲人成国产精品无码| 国产精品欧美久久久久无广告| 99精品全国免费观看视频..| 亚洲国产另类久久久精品| 久久99精品久久久久久秒播| 日本精品在线视频| 99国产欧美精品久久久蜜芽| 无码人妻精品中文字幕| 网友偷拍日韩精品| 欧美精品黑人粗大欧| 国内精品久久久久久久久| 影视网欧洲精品| 久久精品国产一区二区三区日韩| 国产成人亚洲综合无码精品| 久久久久久亚洲精品成人| 欧美成人精品高清在线观看| 亚洲国产精品无码久久98| 四虎精品亚洲一区二区三区| 欧美亚洲另类精品第一页| 国产色精品vr一区区三区| 国产精品麻豆入口| 国产精品国产三级国产a| wwwvr高清亚洲精品二区| 99精品国产一区二区| 91麻精品国产91久久久久| 欧美精品第欧美第12页| 国产成人亚洲合集青青草原精品| 国产成人亚洲精品青草天美| 国产精品亚洲一区二区三区在线| 国产精品嫩草影院AV| 99热亚洲色精品国产88| 99久久精品国产高清一区二区 | 精品人伦一区二区三区潘金莲 | 国产玖玖玖九九精品视频| 99久久精品国产毛片| 午夜精品美女自拍福到在线|