知识分享之Golang——在Golang中管道(channel)的使用

本文介绍了Golang中管道(channel)的使用,包括创建、发送和接收数据以及配合协程实现并发操作。通过示例代码展示了如何利用管道实现数据的先进先出(FIFO)原则,并强调了管道的阻塞特性以及关闭管道的重要性。管道在Golang的并发编程中起到关键作用,可实现数据同步和队列机制。
摘要由CSDN通过智能技术生成

知识分享之Golang——在Golang中管道(channel)的使用

背景

知识分享之Golang篇是我在日常使用Golang时学习到的各种各样的知识的记录,将其整理出来以文章的形式分享给大家,来进行共同学习。欢迎大家进行持续关注。

知识分享系列目前包含Java、Golang、Linux、Docker等等。

开发环境

  • 系统:windows10
  • 语言:Golang
  • golang版本:1.18

内容

本节我们分享在Golang中管道(channel)的使用,在使用管道时我们需要注意:先进先出原则。
以下是其相关代码和使用说明(代码中的注释)

package main

import "fmt"

func main() {
    // 声明一个管道
    var ch chan int
    // 初始化这个管道,让其可以存储10个,注意这里我们可以不给长度,但是由于main主协程会触发死锁,因此有条件时最好增加上去,或者获取的逻辑和写入的逻辑中间有等待
    ch = make(chan int, 10)
    // 向管道中增加10个值
    for i := 0; i < 10; i++ {
        ch <- i
    }
    // 循环打印出来
    for {
        // c是接受对象,ok是本次读取的装填,当管道中没有值了或管道关闭了,这时就会返回false
        c, ok := <-ch
        if ok {
            fmt.Println(c)
        } else {
            break
        }
    }
    // 关闭管道
    close(ch)
}

打印:

0
1
2
3
4
5
6
7
8
9

是不是很简单,当然这个管道配合Golang中的协程,使用起来我们就可以实现各种各样的高并发、队列机制等功能了。

注意:管道本身带有阻塞功能,当我们读取一个空管道时会出现阻塞情况,这时只有这个管道出现数据时才会向下执行。

本文声明:
88x31.png
知识共享许可协议
本作品由 cn華少 采用 知识共享署名-非商业性使用 4.0 国际许可协议 进行许可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CN華少

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值