go Routine1(command12, response12,command13, response13 )go Routine2(command12, response12,command23, response23) // go routineRoutine3(command12, response12,command23, response23 )
这将在新的goroutine中启动Routine1,而主goroutine将继续执行下一条语句。因此,Routine1和Routine2将同时执行,但是Routine2将在Routine2完成后启动。您可能会在这里错过另一个“继续”声明。
然后,我试图遵循您的程序。在Routine1中,您可以
command13 <- y
这将阻止Routine1,直到准备好另一个可以接收您的消息的goroutine。因此,您需要
y :=<-command13在另一个goroutine中使用。
但是现在,让我们仔细看看其他两个goroutine的参数:
Routine2(command12, response12,command23, response23)Routine3(command12, response12,command23, response23 )
如您所见,所有goroutine都不具有对command13的访问权限(但是您要两次传递command12)。因此,Routine1或Routine2或Routine3均无法继续。僵局!
我建议您回到绘图板上。首先考虑您要做什么,绘制一些有关预期消息流的图表,然后尝试实现该行为。
从那时起,真的很难调试程序,
- 我不知道你想做什么。没有有关消息流或类似内容的详细描述。实际上,您的代码根本不包含任何文档。
- 您正在传递通道,这些通道被调用
response23
到名为的参数response13
,依此类推。将它们混合起来很容易。 - 所有这些通用名称(例如command12等)都使您很难理解该通道应该做什么
gofmt
在发布之前,对您的源代码来说这是一个好主意:)
首先,我可以向您推荐Go教程中的“ Prime
Numbers”示例。在此示例中,可能的质数从一个goroutine传递到另一个goroutine。此外,此示例还包含一些有关消息流的漂亮图形以及一些非常好的说明。您可能会喜欢。



