今天就跟大家聊聊有关溶解性golang中的空结构体channel的分析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
省内存,尤其在事件通信的时候。
struct零值就是本身,读取close的channel返回零值
首先事件通知,可以通过写入 通知其他协程,但是只能通知一个。
channel := make(chan struct{})go func() { // ... do something channel <- struct{}{}}()fmt.Println(<-channel)
和close进行配合,通知所有相关协程。
在读入被close的channel返回零值,正常的协程是读取不到这个close的。
close之后,所有协程都可以读到。
比较经典的例子就是用于stopChan作为停止channel通知所有协程。
在下面的例子中 我们可以通过s.Stop()通知所有的serverHandler协程停止工作,并且等待他们正常退出。
type Server struct { serverStopChan chan struct{} stopWg sync.WaitGroup}func (s *Server) Stop() { if s.serverStopChan == nil { panic("gorpc.Server: server must be started before stopping it") } close(s.serverStopChan) s.stopWg.Wait() s.serverStopChan = nil}func serverHandler(s *Server){ for { select { case <-s.serverStopChan: return default: // .. do something } }}
看完上述内容,你们对溶解性golang中的空结构体channel的分析有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://my.oschina.net/u/3358983/blog/4349016