Go并发编程

栏目: IT技术 · 发布时间: 5年前

常见并发模型

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

并发与并行

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

    Go并发编程

    图一.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随机选一个

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

服务设计与创新实践

服务设计与创新实践

宝莱恩 (Andy Polaine)、乐维亚 (Lavrans Lovlie)、里森 (Ben Reason) / 王国胜、张盈盈、付美平、赵芳 / 清华大学出版社 / 2015-6-1 / CNY 69.00

产品经济的时代渐行渐远,在以服务为主导的新经济时代,在强调体验和价值的互联网时代,如何才能做到提前想用户之所想?如何比用户想得更周到?如何设计可用、好用和体贴的服务?这些都可以从本书中找到答案。本书撷取以保险业为代表的金融服务、医疗服务、租车及其他种种服务案例,从概念到实践,有理有据地阐述了如何对服务进行重新设计?如何将用户体验和价值提前与产品设计融合在一起? 《服务设计与创新实践》适合产品......一起来看看 《服务设计与创新实践》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具