您的位置:首页 > 编程语言 > Go语言

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核数。

举个例子

 

 

阅读更多
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: