Go并发编程

常见并发模型

  • 进程 & 线程(Apache)C10K
  • 异步非阻塞(Nginx,Libevent,NodeJS) 复杂度高
  • 协程 (Golang,Erlang,Lua)

并发与并行

  • 并发:指同一时刻,系统通过调度,来回切换交替的运行多个任务,"看起来"是同时进行
  • 并行:指同一时刻,两个任务"真正的"同时进行


    图一.png

Golang并发实现

  • 程序并发执行(goroutine)
  • 多个goroutine间的数据同步和通信(channels)
  • 多个channel选择数据读取或写入(select)
Goroutine(程序并发执行)
foo() //执行函数foo,程序等待函数foo返回

go foo() //执行函数foo
bar() //不用等待foo返回
Channels(多个goroutine间的数据同步和通信)
c := make(chan string) //创建一个channel
go func() {
    time.Sleep(time.Second*1)
   c <- "hello world" //发送数据到channel中
}()
msg := <- c //阻塞直到接收到数据
Select(从多个channel中读取或写入数据)
select{
case v := <-c1:
    fmt.Println("channel 1 send",v)
case v := <-c2:
    fmt.Println("channel 2 send",v)
default: //可选
    fmt.Println("channel was ready")
}
//c1和c2同时有数据时,select随机选一个
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Go 并发编程 选择 Go 编程的原因可能是看中它简单且强大,那么你其实可以选择C语言;除此之外,我看中 Go 的...
    PRE_ZHY阅读 4,379评论 1 6
  • 系统文件介绍 在程序启动运行时,自动打开,运行结束,自动关闭。 键盘(硬件)—— 标准输入(文件)stdin —...
    泡泡龙吐泡泡阅读 10,434评论 0 2
  • 通道 上一次我们讲到了协程,也就是goroutine,并且我们知道了除了goroutine的方式之外,还有一种被称...
    帅气的昵称都有人用了阅读 2,823评论 0 2
  • 1. 访问范围约束 通过限制访问约束,减少不必要的同步带来的性能损耗。例如,集中控制channel的写入,对外提供...
    DDY26阅读 5,451评论 0 1
  • 我在搞创作吗?我喜欢搞创作吗?我能搞创作吗? 我常常问自己,尽管答案似乎并不是肯定的,然而我还是经常在有意无意地以...
    武阳书社阅读 3,106评论 4 3