生活随笔
收集整理的這篇文章主要介紹了
循环开协程情况分析
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
循環開協程情況分析
package mainimport("fmt""runtime""sync"
)//for循環只是用來創建協程而已,當協程創建完成之后,就不再受for控制
func main(){runtime.GOMAXPROCS(1)wg := sync.WaitGroup{}wg.Add(60)for a:=0;a<10;a++{fmt.Println("這里先運行",a)go func(){defer wg.Done()fmt.Printf("a的地址: %p , %v \n",&a,a)}()}for i:=10;i<20;i++{go func(i int){defer wg.Done()fmt.Printf(" i的地址: %p , %v \n",&i,i)}(i)}wg.Wait()fmt.Println("想看運行結果")
}
這里先運行 0
這里先運行 1
這里先運行 2
這里先運行 3
這里先運行 4
這里先運行 5
這里先運行 6
這里先運行 7
這里先運行 8
這里先運行 9i的地址: 0xc000010158 , 19
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10i的地址: 0xc0000101c8 , 10i的地址: 0xc0000101d8 , 11i的地址: 0xc0000101e8 , 12i的地址: 0xc0000101f8 , 13i的地址: 0xc000010208 , 14i的地址: 0xc000010218 , 15i的地址: 0xc000010228 , 16i的地址: 0xc000010238 , 17i的地址: 0xc000010248 , 18
想看運行結果C:\Users\悟\Desktop\studygo\test\waitGroup>go run main.go
這里先運行 0
這里先運行 1
這里先運行 2
這里先運行 3
這里先運行 4
這里先運行 5
這里先運行 6
這里先運行 7
這里先運行 8
這里先運行 9b的地址: 0xc000010158 , 19
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10
a的地址: 0xc000010038 , 10b的地址: 0xc0000101c8 , 10b的地址: 0xc0000101d8 , 11b的地址: 0xc0000101e8 , 12b的地址: 0xc0000101f8 , 13b的地址: 0xc000010208 , 14b的地址: 0xc000010218 , 15b的地址: 0xc000010228 , 16b的地址: 0xc000010238 , 17b的地址: 0xc000010248 , 18
想看運行結果
現象說明
- a的值為什么會是一樣?
- 第一個go func中a是外部變量,因為協程運行時間不確定性,可能此時for循環完之后,才創建完協程,而此時得a=10,協程操作的也是這個變量。因此值會是一樣的。
- b的值為什么會不一樣?
- 第二個go func中b是函數參數,與外部for中的i完全是兩個變量。尾部(i)將發生值拷貝,go func內部將值拷貝。
- b的值輸出不按順序
總結
轉載于:https://www.cnblogs.com/MyUniverse/p/11577357.html
總結
以上是生活随笔為你收集整理的循环开协程情况分析的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。