• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

[阅读笔记]Go语言并发之美

原作者: [db:作者] 来自: [db:来源] 收藏 邀请
文章题目:
     Go语言并发之美

文章链接:
   http://qing.weibo.com/2294942122/88ca09aa33002ele.html

分享笔记:

     这篇文章说的是go routine和channel在Go语言中的应用。刚开始看的时候,对文章使用lua的协程来描述goroutine还真是不习惯。建议读者不要跟者作者使用这样的称呼。

并发在Go中得到语言级别的支持。文章列出了几个goroutine和channel的使用方法

1 id生成器
由于id生成器会产生系统调用,所以假设生成随机数这个id生成函数需要很长时间。这个时候就可以使用到并发了。当一个goroutine在运行的时候,另外一个id生成的goroutine在生成id。

2 多路复用
多路复用就是一个动作可以管理或者监听多个并发线程(这里是goroutine)。文中的例子就是使用一个chan来监听多个goroutine,一旦有一个goroutine对chan进行操作,下面的程序就进行了。
例子的最后也说了,实际上Go也提供了select关键字,因此多路复用也可以使用select来对多个chan进行监听,每个goroutine来通过一个chan来传递消息。

3 实现并发中的future技术
future技术是一种并发模式,需要并发处理的时候,创建goroutine返回一个future,当需要这个future返回东西的时候,去future中获取数据。这样的好处就是在编程的时候的思维逻辑是流式的了。

4 并发循环
使用goroutine来提高循环的效率是最容易想到的优化效率的方法了。

5 chainFilter技术
并发的过滤器可以使用goroutine来使用。这个记得nginx的output就是使用chainFilter这样的模式来实现。

6 共享变量
并发过程中的共享变量的使用有可能发生冲突。当然首选会想到使用锁来对共享变量进行控制。
在golang中也可以使用channel来维护共享变量,实际达到的也是锁的功效。
文中的例子使用一个写通道和一个读通道来保持一个共享变量,只能从写通道写入,这个时候,其他的goroutine要使用写通道是不行的,这就达到了写锁的功能。读的功能也是一样的。

7 使用超时来控制协程泄露
协程泄露说的是协程没有合理控制结束(回收)导致协程无法结束,最终导致程序阻塞无法执行了。
这种情况可以使用超时,使用超时就是另外开启一个goroutine来计时,主goroutine使用多路复用监听要监听的goroutine和计时goroutine。记得某个讲goroutine并发的视频也说到这个。在实际项目中,记得给每个可能“泄露”的goroutine加上计时器是尤为重要的。

ps: 最后吐槽下,这篇文章的程序排版真是不爽。

鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Golang实现将有规律的excel表格转化成struct并一起写入go文件中发布时间:2022-07-10
下一篇:
Go语言中各种数据格式转换发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap