GO语言学习笔记之并发
2018-11-19 14:59
429 查看
如何开始多线程
通过go func()来进行开启
看图:
我们发现这样的操作并不能输出Go方法去输出相应的结果
原因如下:
main线程去执行 ,还没运行Go方法线程时,就结束了main线程因此无法运行Go方法的线程
我们试着让main线程沉睡几秒。这样就有足够的时间去执行Go方法的线程了。
执行顺序是先②,main线程沉睡,再执行①,输出GO GO GO
这让我想到了java中的沉睡机制,然而,go也有类似的机制,叫做管道,go的阻塞机制是通过管道通信的方式而不是共享内存的方式
我们先来试试
首先看看管道怎么定义,类似于map,slice
开启使用make,关闭使用close,并且是引用类型
c:=make(chan bool) make里第一个chan声明是管道类型,bool声明该管道的类型是bool型
先看一个例子吧
①是获取管道数据,②是将true存入管道
运行顺序如下:main函数执行没执行Go函数的时候就到了①,此时①去取,却发现没有数据可取,那么这是main线程阻塞,这时Go函数开始了执行,在②的时候存入了true,这是切换回了main线程执行①,发现数据可取,不再阻塞main线程。结束。
注意我们并没有close(c),因为main线程全部执行完自动销毁了c
我们还可以通过for range不断操作channal
执行顺序:main线程执行到①,此时等待有一个chan进去,然后到Go线程,此时进行③传入值,这时这个线程阻塞,调到②,
然后range一直遍历,此时跳回④,关闭后,跳回range发现chan关闭结束
在go1.5后自动将设置核数为当前cpu核数。
举个例子
阅读更多
相关文章推荐
- Go语言并发与并行学习笔记(一)
- Go语言并发与并行学习笔记(三)
- Go语言并发与并行学习笔记(一)
- Go语言并发与并行学习笔记(二)
- JAVA并发编程学习笔记------锁顺序死锁
- 并发编程学习笔记之Lock与synchronized
- 关于Android SQLite3多线程并发问题,学习笔记。
- 微信公号“架构师之路”学习笔记(二)-高可用高并发负载均衡的架构设计(冗余+自动故障转移、水平扩展等)
- java大数据学习笔记(四) 并发集合
- Java 并发编程学习笔记之Synchronized底层优化
- 关于Android SQLite3多线程并发问题,学习笔记。
- 并发学习笔记
- Go 并发concurrency 学习笔记
- SSM框架学习之高并发秒杀业务--笔记4-- web层
- python学习笔记:多并发(线程、进程、协程)
- Go语言并发与并行学习笔记(一)
- JUC学习笔记--JUC中并发工具类
- Java并发读书学习笔记(五)——任务执行
- Java并发学习笔记(1) 线程与进程
- Java并发学习笔记(10)线程同步容器