golang 的 goroutine 和 channel

文章目录

    • [无缓冲的 channel](#无缓冲的 channel)
    • [有缓冲的 channel](#有缓冲的 channel)
    • [创建一个无缓冲的 channel 并在 select 语句中使用](#创建一个无缓冲的 channel 并在 select 语句中使用)
    • [goroutine 和 channel 生产者-消费者模型](#goroutine 和 channel 生产者-消费者模型)

无缓冲的 channel

无缓冲的 channel 在发送和接收操作时会阻塞,直到另一端准备好。

go 复制代码
ch := make(chan int)

有缓冲的 channel

带缓冲的 channel 在缓冲区未满时,发送操作不会阻塞;在缓冲区有数据时,接收操作不会阻塞。

go 复制代码
ch := make(chan int, 10) // 缓冲区大小为 10

创建一个无缓冲的 channel 并在 select 语句中使用

可以在 select 语句中使用 channel。

go 复制代码
func main() {
    ch := make(chan int)
    go func() {
        ch <- 42
    }()
    select {
    case val := <-ch:
        fmt.Println(val)
    }
}
  • 使用 make 函数创建 channel。
  • 可以创建无缓冲或带缓冲的 channel。
  • 可以通过方向操作符 <- 来限制 channel 的发送或接收能力。
  • channel 常用于 goroutine 之间的通信和同步。

goroutine 和 channel 生产者-消费者模型

不论 1:n 还是 n:1 或是 n:m,都可以使用 sync.WaitGroup 下面这种模型来操作。

go 复制代码
package main

import (
	"fmt"
	"sync"
	"time"
)

func producer(id int, jobs chan<- int, wg *sync.WaitGroup) {
	defer wg.Done()
	for i := 0; i < 5; i++ {
		time.Sleep(time.Millisecond * 100)
		jobs <- i
		fmt.Printf("Producer %d produced %d\n", id, i)
	}
}

func consumer(id int, jobs <-chan int, wg *sync.WaitGroup) {
	defer wg.Done()
	for job := range jobs {
		time.Sleep(time.Millisecond * 500)
		fmt.Printf("Consumer %d consumed %d\n", id, job)
	}
}

func main() {
	jobs := make(chan int, 10)
	var wg sync.WaitGroup

	const numProducers = 3
	const numConsumers = 2
	wg.Add(numProducers)
	for i := 0; i < numProducers; i++ {
		go producer(i, jobs, &wg)
	}

	wg.Add(numConsumers)
	for i := 0; i < numConsumers; i++ {
		go consumer(i, jobs, &wg)
	}

	wg.Wait()
	close(jobs)
}
相关推荐
Run_Teenage2 分钟前
我的创作纪念日
c语言·开发语言
程序员顾茗3 分钟前
从 @SpringBootApplication 出发,深度剖析 Spring Boot 自动装配原理
java·spring boot·后端
uhakadotcom17 分钟前
WebAssembly反爬虫技术:隐藏核心逻辑和加密数据
后端·面试·github
青木川崎35 分钟前
java基础之windows电脑基础命令
java·开发语言·windows
无眠_42 分钟前
Spring Boot Bean 的生命周期管理:从创建到销毁
java·spring boot·后端
癞皮狗不赖皮2 小时前
WEB攻防- PHP反序列化&属性权限特征&原生类 TIPS&字符串逃逸&CVE 绕过漏洞
开发语言·php
UpUpUp……2 小时前
C++继承与组合完结
开发语言·c++·笔记
淘小欣2 小时前
10分钟打造专属AI助手:用ms-swift实现自我认知微调
开发语言·人工智能·ai·swift·模型微调
搬砖工程师Cola3 小时前
<C#> 详细介绍.net 三种依赖注入:AddTransient、AddScoped、AddSingleton 的区别
开发语言·c#·.net
z26373056113 小时前
springboot继承使用mybatis-plus举例相关配置,包括分页插件以及封装分页类
spring boot·后端·mybatis