我从github上的某人那里得到了这段代码,我正在尝试使用它来理解并发性。
package main
import (
"bufio"
"fmt"
"os"
"sync"
"time"
)
var wg sync.WaitGroup
func sad(url string) string {
fmt.Printf("gonna sleep a bit\n")
time.Sleep(2 * time.Second)
return url + " added stuff"
}
func main() {
sc := bufio.NewScanner(os.Stdin)
urls := make(chan string)
results := make(chan string)
for i := 0; i < 20; i++ {
wg.Add(1)
go func() {
defer wg.Done()
for url := range urls {
n := sad(url)
results <- n
}
}()
}
for sc.Scan() {
url := sc.Text()
urls <- url
}
for result := range results {
fmt.Printf("%s arrived\n", result)
}
wg.Wait()
close(urls)
close(results)
}
我有几个问题:
为什么此代码会给我带来死锁?
在从用户接收输入的操作之前,for循环是如何存在的,go例程是否等到任何内容在urls通道中传递然后开始工作?我没有得到这个,因为它不是连续的,比如为什么从用户那里接收输入,然后将每个输入放在urls通道中,然后运行go例程被认为是错误的?
在for循环中,我有另一个循环,它正在迭代urls通道,每个go例程是否只处理一行输入?还是一个人一次例行处理多条线?这些是如何工作的?
我在这里正确收集输出吗?
繁花不似锦
梦里花落0921
鸿蒙传说
相关分类