Go并发编程之二

一、前言

前一篇 Go并发编程之一 主要介绍了如何通过go语句启动协程(goroutine)以及协程调度的不确定性,这一篇我们重点来介绍一下协程中另外一个重要概念channel,记住第一句话:

goroutine之间不是通过共享内存来通信,而是通过通信来共享内存。

二、通道channel

1、创建通道

ch := make(chan string)

注:这里创建的是无缓存通道,这一节我们也只讲无缓存通道。创建通道时是需要指定通道的数据类型。

2、向通道发送数据

ch <- data

3、从通道接收数据

data := <-ch

注:这个语法有点不好写,可以理解为箭头往那边去就是往那里写数据,类似于Linux的文件重定向语法。

记住第二句话:

**同一时刻只能有一个goroutine能向通道发送数据,也只能有一个goroutine从这个通道接收数据。**这就彻底保证了通道的数据是goroutine安全的,而其它编程语言中共享内存是需要加锁来保证数据安全。

理论的东东不多讲,我讲出来可能也不一定严谨,先来看一个例子。

三、例子

注:这个例子来源于Microsoft,写得很好直接搬过来用了,Go是Google搞的,但微软有很好Go语言入门培训文档 (https://docs.microsoft.com/zh-cn/learn/paths/go-first-steps/),关键还是中文的。不太谦虚地讲,他的文档写得比我好100倍,如果谦虚地讲。。。。。

通道可以做为函数参数,这样在子goroutine里就可以向通道发送数据,然后在主goroutine里就可以从通道中取出执行结果数据,这里启动了6个协程去请求URL,然后因为通道一个重要的特性:如果通道数据没有接收,发送方会被阻塞,这样就会等6个协程都执行完数据被接收后,主流程才会往后执行。

做业务系统开发碰到关于多线程最多的就是处理大量数据,如果在Java或Python中要多线程处理数据,代码就会写得很复杂,而用Go代码是如此简洁。

相关推荐
Dxy12393102162 分钟前
Python在图片上画圆形:从入门到实战
开发语言·python
小江的记录本3 分钟前
【系统设计】《2026高频经典系统设计题》(秒杀系统、短链接系统、订单系统、支付系统、IM系统、RAG系统设计)(完整版)
java·后端·python·安全·设计模式·架构·系统架构
掘金者阿豪7 分钟前
我用 CODEX(GPT-5.4) 写代码一个多月后,突然开始害怕自己的项目了
后端
希望永不加班11 分钟前
SpringBoot 中 AOP 实现权限校验(角色/权限)
java·spring boot·后端·spring
北漂Zachary15 分钟前
四大编程语言终极对决:汇编/C#/Go/Java谁更强
汇编·golang·c#
掘金者阿豪21 分钟前
接手一个烂摊子之后:金仓数据库开发规范实战笔记
后端
桌面运维家22 分钟前
IDV云桌面vDisk机房部署方案模板特性解析
java·开发语言·devops
飞翔的SA26 分钟前
从6.75%到100%!大模型Function Calling终极方案:Harness工程如何驯服
开发语言·ai·llm·harness
耿雨飞39 分钟前
Python 后端开发技术博客专栏 | 第 09 篇 GIL 深度解析与并发编程实战 -- 多线程、多进程、协程的选型
开发语言·python
Stark-C40 分钟前
NAS音乐必备神器,全平台音乐收割机!极空间部署『Go Music DL』
开发语言·后端·golang