golang实现简单的排队系统,报错,死锁,求大神指教

JustOneBall · 2017-12-18 02:08:31 · 1808 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2017-12-18 02:08:31 的主题,其中的信息可能已经有所发展或是发生改变。

代码是这个样子的,我就是想用用并发的功能做个小样子,结果一直报错,报错信息见代码下方 package main

import ( "fmt" "sync" "time" )

func main() { var wg sync.WaitGroup server := make(chan int)

for i := 0; i < 3; i++ {
    time.Sleep(time.Second)
    wg.Add(1)
    go func(id int) {
        fmt.Println("A Customer is Coming")
        <-server
        fmt.Println("A Customer is Being Served")
        time.Sleep(2 * time.Second)
        fmt.Println("Service is finished, the customer is leaving")
        server <- 1
        wg.Done()
    }(i)
}
for i := 0; i < 2; i++ {
    server <- 1
}
wg.Wait()
close(server)
fmt.Println("Over")

}

错误信息:fatal error: all goroutines are asleep - deadlock!


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1808 次点击  
加入收藏 微博
6 回复  |  直到 2017-12-19 22:11:59
iuoui
iuoui · #1 · 7年之前

你第一个for循环中的go func里面,那个 <- server,在这里阻塞了,把它去掉,你再理一理

JustOneBall
JustOneBall · #2 · 7年之前

我解决我的问题了,是我在初始化channel的时候没有设置缓存量,所以当go func 和main一起操作channel时,就会死锁,好像是这么回事。 <- server这个我想表达的是有一个server接待了来的这个顾客。 谢谢你的回复

specita
specita · #3 · 7年之前

协程里面的server<-1去掉,然后第二个for循环的条件改成 i < 3 , 这段代码为什么会dead lock,因为 <-chan 或者 chan <- 都会阻塞,如果只有其中一个,那就会dead lock

wonder_wjy
wonder_wjy · #4 · 7年之前

首先三个 goruntime 0,1,2都是阻塞的,等待CHAN

for i := 0; i < 2; i++ { server <- 1 }

这里会触发两个goruntime 0 和 1的程序执行,假设0优先,当0执行完后,会去写 server <- 1,那么goruntime 2会执行, 当 1 和 2执行完之后去写 server <- 1,但是这里就会阻塞了,因为没有任何去读的地方。主线程wg.Wait()也会一直阻塞,所以所有线程都是阻塞的

thinkeridea
thinkeridea · #5 · 7年之前

使用的是同步的chan, 程序中有3个goroutine, 每个goroutine写一次,读一次, goroutine外面对chan写了两次,执行goroutine时会有两个goroutine在最后无法写入,导致wg.Wait()阻塞, wg.Wait()检测已经没有其它goroutine了,所以报错all goroutines are asleep - deadlock!

juntaran
juntaran · #6 · 7年之前
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传