大家好,我是渔夫子。
成都创新互联-成都网站建设公司,专注成都网站设计、成都网站建设、网站营销推广,国际域名空间,网络空间,网站托管维护有关企业网站制作方案、改版、费用等问题,请联系成都创新互联。
今天给大家介绍的go channel的第二种应用:协程间同步信息。
通过channel,能够确保一个协程在另一个协程完成工作之后才能继续。如果需要在两个或多个协程之间共享数据的场景中,这种用法就特别有用,并且能够确保数据不会同时被多个协程修改非常重要。
我们先看一个简单的示例:
package main
import (
"fmt"
"time"
)
func worker(done chan bool) {
fmt.Print("working...")
time.Sleep(time.Second)
fmt.Println("done")
done <- true
}
func main() {
done := make(chan bool, 1)
go worker(done)
<-done
}
在这个示例中,我们创建了一个worker协程,同时在main协程中创建了一个done通道。当worker协程完成工作后,往done通道中发送了一个true,代表通知main协程worker执行完毕了。
接下来我们看几个开源项目中的示例。
在gin框架的example中,有一个关闭服务的示例,就是利用了通道来在两个协程间进行通讯的特性。如下:
图片
这里就是在main协程中创建了一个quit通道,然后并将该quit通道传递给signal.Notify函数,然后通过<-quit阻塞等待signal.Notify函数执行完毕。在signal.Notify中其实是注册并监听syscall.SIGTERM信号,通过启动了一个新的协程来监听该信号。当该信号发生时,就往quit通道中写入一个os.Signal的数据。
在fastcache开源项目中,有个功能是将数据保存到文件中。在保存函数中用到了并发保存,同时需要将每个保存的结果输出。下面就是通过通道来接收每个协程的保存结果的功能。如下:
图片
在上图中,首先在save函数中初始化了一个results通道,然后将saveBuckets的结果输出到results。在save函数的最下面,通过从results等待输出每次saveBuckets的结果。你看,这里就是通过results通道将子协程中的结果输出给save函数(父协程)了。
好了,今天通道的应用案例就分享到这里了。
分享文章:GoChannel应用:协程间信息同步
路径分享:http://www.shufengxianlan.com/qtweb/news23/396373.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联