Golang并发、协程

水无寒 · · 1496 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

并行(parallel):指在同一时刻,有多条指令在多个处理器上同时执行。

并发(concurrency):指在同一时刻只能有一条指令执行,但多个进程指令被快速的轮换执行,使得在宏观上具有多个进程同时执行的效果,但在微观上并不是同时执行的,只是把时间分成若干段,使多个进程快速交替的执行。

goroutine

goroutine是比线程更小的工作单元,go语言内部实现了goroutine之间的内存共享,它比thread更易用、更高效、更轻便。

创建goroutine

只需要在函数调用语句前添加"go"关键字,就可以创建并发执行单元。当一个程序启动时,其主函数即在一个单独的goroutine中运行,称为main goroutine。当主协程结束的时候,子协程也会自动结束。

Gosched

runtime包的方法,让出时间片,让其它协程先执行

Goexit

runtime 包的方法,终止所在协程

GOMAXPROCS

runtime包的方法,获取最大核心数,指定使用核心数

channel

channel是内置的数据结构,用于读取发送数据,无数据时,读取数据会阻塞,设置了最大写入数据时,写满capacity个元素时,写入阻塞。

channel创建

make(chan Type)

make(chan Type, capacity)

channel读写

ch <- 666

<- ch

无缓冲的channel

make(chan Type)

make(chan Type,0)

有缓冲的channel

是一种在被接受前能存储一个或多个值得channel

make(chan Type,3)

单向channel

var send chan<- int

var receiver <-chan int


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:水无寒

查看原文:Golang并发、协程

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1496 次点击  
加入收藏 微博
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传