GoLang并发简单例子(goroutine + channel + WaitGroup)

文章目录

go 复制代码
package main

import (
	"fmt"
	"sync"
)

// 帮忙统计有多少个 goroutine 需要等待,以及什么时候它们都结束了。
var wg sync.WaitGroup

func printer(ch chan int) {
	for i := range ch {
		fmt.Printf("Received %d ", i)
	}
	// wg.Done() 表示:这个 goroutine 已经执行完它的任务了。	
	// 内部等价于 wg.Add(-1):
	// 把 WaitGroup 的计数减 1。	
	// 当计数变成 0 时,任何 wg.Wait() 正在阻塞的 goroutine 都会被唤醒
	wg.Done()
}

// main is the entry point for the program.
func main() {
	// 创建了一个 无缓冲(unbuffered) 的 channel,类型为 chan int。
	// 无缓冲的意思是:
	// 发送 c <- i 会阻塞,直到有另外一个 goroutine 正在从 c 读数据;
	// 接收 <-c 也会阻塞,直到有别人发送。
	c := make(chan int)

	// "我有 1 个 goroutine 要等"。
	wg.Add(1)

	go printer(c)

	// Send 10 integers on the channel.
	// 阻塞行为:因为 c 是一个无缓冲通道,所以每次主函数发送数据时,都会被阻塞,直到有另一个 goroutine 从该通道中接收数据。如果没有 goroutine 在接收通道中的数据,主 goroutine 会停在那里,等待 printer goroutine 来接收数据。
	for i := 1; i <= 10; i++ {
		c <- i
	}

	close(c)
	wg.Wait()
	fmt.Println()
}

之后我会持续更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗感谢支持!

相关推荐
MarkHD14 小时前
智能体在车联网中的应用:第51天 模仿学习与离线强化学习:破解数据效率与安全困局的双刃剑
学习·安全
追逐时光者16 小时前
一个致力于为 C# 程序员提供更佳的编码体验和效率的 Visual Studio 扩展插件
后端·c#·visual studio
molaifeng17 小时前
Go 语言如何实现高性能网络 I/O:Netpoller 模型揭秘
开发语言·网络·golang
Drawing stars17 小时前
JAVA后端 前端 大模型应用 学习路线
java·前端·学习
崇山峻岭之间17 小时前
Matlab学习记录33
开发语言·学习·matlab
Evand J17 小时前
【2026课题推荐】DOA定位——MUSIC算法进行多传感器协同目标定位。附MATLAB例程运行结果
开发语言·算法·matlab
行百里er18 小时前
用 ThreadLocal + Deque 打造一个“线程专属的调用栈” —— Spring Insight 的上下文管理术
java·后端·架构
jllllyuz18 小时前
基于MATLAB的二维波场模拟程序(含PML边界条件)
开发语言·matlab
忆锦紫18 小时前
图像增强算法:Gamma映射算法及MATLAB实现
开发语言·算法·matlab
玄〤18 小时前
黑马点评中 VoucherOrderServiceImpl 实现类中的一人一单实现解析(单机部署)
java·数据库·redis·笔记·后端·mybatis·springboot