I was wondering if it's possible to do a task (like a function, with different arguments, e.g. int multipliers) run at the same time, and a variable which receive the return value of the first task finished. Someone has any idea? :D
1条回答 默认 最新
- dousou3027 2015-06-23 16:53关注
Here is a basic example though there are plenty of others on the internet... https://play.golang.org/p/R__dk09Ymh
package main import "fmt" import "time" func main() { a := make(chan bool) b := make(chan bool) go MySleep(5000, a) go MySleep(1000, b) select { case _ = <-a: fmt.Println("a returned first") case _ = <-b: fmt.Println("b returned first") } } func MySleep(t int, sig chan bool) { time.Sleep(time.Duration(t)) close(sig) return }
You can extend this to do whatever you want. For example if you want to spin of some arbitrary number of goroutines
N
and not stop until they're all complete then you could wrap the select in a for and add a flag to indicate that each goroutine has sent on it's channel. Note that a well made program would also have communication in the other direction so you can shut down your workers.本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥30 VMware 云桌面水印如何添加
- ¥15 用ns3仿真出5G核心网网元
- ¥15 matlab答疑 关于海上风电的爬坡事件检测
- ¥88 python部署量化回测异常问题
- ¥30 酬劳2w元求合作写文章
- ¥15 在现有系统基础上增加功能
- ¥15 远程桌面文档内容复制粘贴,格式会变化
- ¥15 这种微信登录授权 谁可以做啊
- ¥15 请问我该如何添加自己的数据去运行蚁群算法代码
- ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”