go理论知识——Go Channel 笔记 [特殊字符]

embedded/2025/2/1 6:28:51/

go理论知识——Go Channel 笔记 📝

1. 基本概念 🧠

1.1 Channel 是什么?

  • Channel 是 Go 语言中用于在不同 Goroutine 之间进行通信的机制。
  • Channel 是类型安全的,意味着你只能发送和接收特定类型的数据。

1.2 Channel 的创建 🏗️

  • 使用 make 函数创建 Channel:
  c := make(chan int)
  • 可以创建带缓冲的 Channel:
  c := make(chan int, 3) // 缓冲区大小为 3

2. 无缓冲 Channel 🚫

2.1 无缓冲 Channel 的特性

  • 无缓冲 Channel 是同步的,发送和接收操作会阻塞,直到另一端准备好。
  • 示例代码:
    c := make(chan int)
    go func() {defer fmt.Println("goroutine 结束")fmt.Println("goroutine is running……")c <- 666
    }()
    num := <-c
    fmt.Println("num = ", num)
    

image-20250127232441634

2.2 运行结果

  • Goroutine 会发送 666 到 Channel,主 Goroutine 会接收并打印这个值。

3. 带缓冲 Channel 🛠️

3.1 带缓冲 Channel 的特性

  • 带缓冲 Channel 是异步的,只有在缓冲区满时发送操作才会阻塞,只有在缓冲区空时接收操作才会阻塞。
  • 示例代码:
    c := make(chan int, 3)
    go func() {for i := 0; i < 3; i++ {c <- ifmt.Println("子go程正在运行,发送的元素:", i, " len(c) = ", len(c), " cap(c) = ", cap(c))}
    }()
    time.Sleep(2 * time.Second)
    for i := 0; i < 3; i++ {num := <-cfmt.Println("父go程正在运行,收到的元素:", num, " len(c) = ", len(c), " cap(c) = ", cap(c))
    }
    

3.2 运行结果

  • 子 Goroutine 会发送 3 个元素到 Channel,主 Goroutine 会接收并打印这些元素。

4. 关闭 Channel 🚪

4.1 关闭 Channel 的作用

  • 使用 close 函数关闭 Channel,关闭后不能再发送数据,但可以继续接收数据。
  • 示例代码:
    c := make(chan int)
    go func() {for i := 0; i < 5; i++ {c <- i}close(c)
    }()
    for data := range c {fmt.Println(data)
    }
    

4.2 注意事项

  • 只有在没有任何数据需要发送时才关闭 Channel。
  • 关闭后的 Channel 不能再发送数据,但可以继续接收数据。

5. Select 语句 🔄

5.1 Select 语句的作用

  • select 语句用于在多个 Channel 操作中进行选择,类似于 switch 语句。
  • 示例代码:
    c := make(chan int)
    quit := make(chan int)
    go func() {for i := 0; i < 6; i++ {fmt.Println(<-c)}quit <- 0
    }()
    fibonacii(c, quit)
    

image-20250127232414168

image-20250127232338384

5.2 运行结果

  • fibonacii 函数会生成斐波那契数列并通过 Channel 发送,直到接收到 quit 信号。

6. 总结 📌

  • Channel 是 Go 语言中非常重要的并发编程工具。
  • 无缓冲 Channel 是同步的,带缓冲 Channel 是异步的。
  • 使用 close 关闭 Channel,使用 select 处理多个 Channel 操作。

http://www.ppmy.cn/embedded/158558.html

相关文章

CRC校验详解

CRC校验即循环冗余校验(Cyclic Redundancy Check),是基于数据计算一组效验码,用于核对数据传输过程中是否被更改或传输错误。首先看两个概念,后续会用到。 模2除法:也叫模2运算,就是结果除以2后取余数。模2除法每一位除的结果不影响其它位,即不向上一位借位,所以实际…

IP服务模型

1. IP数据报 IP数据报中除了包含需要传输的数据外&#xff0c;还包括目标终端的IP地址和发送终端的IP地址。 数据报通过网络从一台路由器跳到另一台路由器&#xff0c;一路从IP源地址传递到IP目标地址。每个路由器都包含一个转发表&#xff0c;该表告诉它在匹配到特定目标地址…

数据分析系列--④RapidMiner进行关联分析(案例)

一、核心概念 1.项集&#xff08;Itemset&#xff09; 2.规则&#xff08;Rule&#xff09; 3.支持度&#xff08;Support&#xff09; 3.1 支持度的定义 3.2 支持度的意义 3.3 支持度的应用 3.4 支持度的示例 3.5 支持度的调整 3.6 支持度与其他指标的关系 4.置信度&#xff0…

前后分离Vue3+Django 之简单的登入

前端Vue3 <template><div><el-form :model"form" label-width"100px"><el-form-item label"用户名"><el-input v-model"form.username" placeholder"请输入用户名"></el-input></e…

【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】1.28 存储之道:跨平台数据持久化方案

好的&#xff0c;我将按照您的要求生成一篇高质量的Python NumPy文章。以下是第28篇《存储之道&#xff1a;跨平台数据持久化方案》的完整内容&#xff0c;包括目录、正文和参考文献。 1.28 存储之道&#xff1a;跨平台数据持久化方案 目录 #mermaid-svg-n1z37AP8obEgptkD {f…

大模型知识蒸馏技术(1)——蒸馏技术概述

版权声明 本文原创作者:谷哥的小弟作者博客地址:http://blog.csdn.net/lfdfhl1. 概述 1.1 核心概念与定义 知识蒸馏是一种模型压缩和知识迁移的技术,其核心思想是利用一个预先训练好的大型复杂模型(教师模型)作为“教师”,指导训练一个更小更轻量级的模型(学生模型)。…

线性调整器——耗能型调整器

线性调整器又称线性电压调节器&#xff0c;以下是关于它的介绍&#xff1a; 基本工作原理 线性调整器的基本电路如图1.1(a)所示,晶体管Q1(工作于线性状态,或非开关状态)构成一个连接直流源V和输出端V。的可调电气电阻,直流源V由60Hz隔离变压器&#xff08;电气隔离和整流&#…

硬件电路(5)-压敏电阻

一、概述 压敏电阻&#xff0c;顾名思义&#xff0c;对电压很敏感的电阻&#xff1b;中文这个“敏感”对应到电路中&#xff0c;应该就是一个非线性的变化&#xff1a;当电压达到一定的数值的时候&#xff0c;器件的阻抗呈现出剧烈的变化&#xff0c;这个剧烈的变化应该是量级上…