博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[阅读笔记]Go语言并发之美
阅读量:6227 次
发布时间:2019-06-21

本文共 1266 字,大约阅读时间需要 4 分钟。

文章题目:

     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: 最后吐槽下,这篇文章的程序排版真是不爽。

本文转自轩脉刃博客园博客,原文链接:http://www.cnblogs.com/yjf512/archive/2012/11/30/2796892.html,如需转载请自行联系原作者

你可能感兴趣的文章
leetcode — recover-binary-search-tree
查看>>
leetcode — symmetric-tree
查看>>
Parencodings
查看>>
web服务端重定向
查看>>
浅谈薄见
查看>>
Session模型简介
查看>>
C实现shell管理的一个例子
查看>>
为ASP.NET控件加入快捷菜单
查看>>
Tftod 的服务器使用下载文件
查看>>
装机、UEFI双系统安装
查看>>
jsp入门
查看>>
Android-----使用Button特效 selector+shape
查看>>
android获取/更改gps和WIFI状态
查看>>
自定义线程池
查看>>
SQL Server性能优化(11)非聚集索引的覆盖索引存储结构
查看>>
Django后台管理定制admin
查看>>
从源码分析scrollTo、scrollBy、Scroller方法的区别和作用
查看>>
购买内存条的几点方法
查看>>
[51Nod1487]占领资源
查看>>
Asymptote 学习记录(1):基本的安装以及用批处理模式和交互模式绘图
查看>>