go语言学习9:并发 goroutine channel

提到并发编程,就不得不理清2个概念:并发,并行

  • 并发是多个线程的任务执行,实际上是cpu时间段的抢夺。
  • 并行是每个任务分配给一个cpu执行,指的多核任务同时执行。

协程:比线程更轻量级,一个线程可以有多个协程。
协程是编译器级的,进程和线程是操作系统级的。协程不被操作系统内核管理,而完全由程序控制,因此没有线程切换的开销。和多线程比,线程数量越多,协程的性能优势就越明显。协程的最大优势在于其轻量级,可以轻松创建上万个而不会导致系统资源衰竭。
(go中如何进行细粒度的线程或者协程控制?)
在这里插入图片描述

协程的创建

普通创建

Goroutine使用起来非常简单,只需在要让Goroutine执行的函数或方法前加上关键字go即可。
在这里插入图片描述

匿名创建

在这里插入图片描述

channel

Go语言中提倡使用channel的方式代替共享内存。换言之,Go语言主张通过数据传递来实现共享内存,而不是通过共享内存来实现数据传递。
Go语言中的通道(channel)是一种特殊的类型。在任何时候,同时只能有一个goroutine访问通道进行发送和获取数据。goroutine间通过通道就可以通信。
在这里插入图片描述
在这里插入图片描述
channel发送的值的类型必须与channel的元素类型一致。如果接收方一直没有接收,那么发送操作将持续阻塞。此时所有的Goroutine,包括main()的Goroutine都处于等待状态。

sync

加锁同步,sync包和java中的lock比较类似

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值