下面代码片段,为什么执行到counter3000多,就不执行了。另外如果去掉fmt.Println("counterinmain:",counter)的注释,就可以执行完毕。这是为什么啊?09-02update:是在main()中第二个for循环卡死了,就是感觉goroutines没有执行完或者没有按预期执行(预期最后counter值会为9000)。但是去掉注释就不会卡死。另外今天在公司电脑,这个偶尔会卡死,偶尔又不会卡死,不知道为什么。packagemainimport("fmt""sync")varcounterint=0funcCount(iint,lock*sync.Mutex){lock.Lock()fmt.Println("BeforeCount()",i,counter)counter++fmt.Println("AfterCount()",i,counter)lock.Unlock()}funcmain(){lock:=&sync.Mutex{}fori:=0;i<9000;i++{goCount(i,lock)}for{//fmt.Println("counterinmain:",counter)ifcounter>=9000{break}}}
相关分类