返回顶部
首页 > 资讯 > 精选 >怎么使用go带缓冲chan实现消息队列功能
  • 378
分享到

怎么使用go带缓冲chan实现消息队列功能

2023-07-05 07:07:58 378人浏览 八月长安
摘要

本篇内容介绍了“怎么使用Go带缓冲chan实现消息队列功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、Channels 定义通道是一种

本篇内容介绍了“怎么使用Go带缓冲chan实现消息队列功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

1、Channels 定义

通道是一种支持多类型的管道,您可以通过它使用通道运算符 <- 发送和接收值。

数据沿箭头方向流动。

ch <- v    // Send v to channel ch.v := <-ch  // Receive from ch, and           // assign value to v.

与 maps 和 slices 一样,通道必须在使用前创建:

ch := make(chan int)

默认情况下,发送和接收阻塞,直到另一方准备就绪。
这允许 goroutines 在没有显式或条件变量的情况下进行同步。

package mainimport "fmt"func sum(s []int, c chan int) {    sum := 0    for _, v := range s {        sum += v    }    c <- sum // send sum to c}func main() {    s := []int{7, 2, 8, -9, 4, 0}    c := make(chan int)    go sum(s[:len(s)/2], c)    go sum(s[len(s)/2:], c)    x, y := <-c, <-c // receive from c    fmt.Println(x, y, x+y)}

2、chan 常用操作

  • 无缓冲区: 存入读取一次,存入后未取,再存入就会堵塞,同样未存,就取也会堵塞。

  • 有缓冲区: 只有当缓冲区满了,才会堵塞存;只有缓冲区空时,才会堵塞取。

  • len(channel) 返回缓冲区现有数据长度

  • cap(channel) 返回缓冲区的大小

  • close(channel) 关闭 channel,关闭后,读取不到数据。如下,如果其他协程关掉 channel 则会跳出循环

3、带缓冲chan实现消息队列功能

// 监测数据结构体type Msg struct {    Timestamp    int64    Content        string        }// 用 chan 模拟队列,队列的元素为 Msg 类型var SyncQueen chan Msg// 必须初始化才能使用。初始化一个容量为1024的 chan。chan 满时会阻塞func init() {    SyncQueen = make(chan Msg, 1024)}
// 队列消费者func Consumer() {    defer func() {        if err := recover(); err != nil {            fmt.Println(err)        }    }()    for {        // chan 内无消息则阻塞        msg := <-SyncQueen        fmt.Println(msg.Content)    }}
// 队列生产者func Producer() {    for {        msg := Msg(time.now().Unix(), "hello")                // 发送消息到 chan        SyncQueen <- msg        time.Sleep(2 time.Second)    }}

重点

多协程使用chan是并发安全的,以下展示一个简单的例子:

// 定义类型为 int 的 chanvar chanNums chan int// chan 的消费者,用户后续多协程// 目的:数组里存储了10000个数字,多个协程并行计算后,把和加起来func consumer(sum *int) int {    for {        v := <-chanNums        *sum += v    }}//-------------------------------------func main() {    var a [10000]int    for i := 0; i < 10000; i++ {        a[i] = i + 1    }    chanNums = make(chan int, 10000)    for i := 0; i < 10000; i++ {        chanNums <- (i + 1)    }    var s1, s2, s3, s4, s5 int = 0, 0, 0, 0, 0    go consumer(&s1)    go consumer(&s2)    go consumer(&s3)    go consumer(&s4)    go consumer(&s5)    for {        time.Sleep(5 * time.Second)        break    }    fmt.Println("s1=", s1, "s2=", s2, "s3=", s3, "s4=", s4, "s5=", s5)    fmt.Println("sum=", s1+s2+s3+s4+s5)}// 输出s1= 10818438 s2= 12073966 s3= 9044041 s4= 11509634 s5= 6558921sum= 50005000

“怎么使用go带缓冲chan实现消息队列功能”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: 怎么使用go带缓冲chan实现消息队列功能

本文链接: https://lsjlt.com/news/350270.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • go带缓冲chan实现消息队列功能
    目录1、Channels 定义2、chan 常用操作3、带缓冲chan实现消息队列功能重点1、Channels 定义 通道是一种支持多类型的管道,您可以通过它使用通道运算符 <...
    99+
    2023-02-28
    go缓冲chan消息队列 go chan消息队列
  • 怎么使用go带缓冲chan实现消息队列功能
    本篇内容介绍了“怎么使用go带缓冲chan实现消息队列功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、Channels 定义通道是一种...
    99+
    2023-07-05
  • golang怎么实现消息队列功能
    Golang可以使用第三方库来实现消息队列功能,常用的库有NSQ、RabbitMQ和Apache Kafka等。下面以NSQ为例,介...
    99+
    2023-10-20
    golang
  • go怎么实现消息队列
    在Go语言中,你可以使用第三方库来实现消息队列。目前比较常用的消息队列库有:1. RabbitMQ:RabbitMQ是一个开源的消息...
    99+
    2023-08-31
    go
  • Redis如何实现消息队列功能
    Redis如何实现消息队列功能随着互联网的发展,消息队列在分布式系统中变得越来越重要。消息队列允许不同的应用程序之间通过异步通信来传递和处理消息,提高了系统的可伸缩性和可靠性。Redis作为一款快速、可靠、灵活的内存数据库,也可以用来实现消...
    99+
    2023-11-07
    redis 实现 消息队列
  • Redis怎么使用ZSET实现消息队列
    这篇文章主要介绍了Redis怎么使用ZSET实现消息队列的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Redis怎么使用ZSET实现消息队列文章都会有所收获,下面我们一起来看看吧。1.redis 用zset做消...
    99+
    2023-07-05
  • 如何在Redis中实现消息队列功能
    在Redis中实现消息队列功能通常可以通过使用Redis的List数据结构来实现。以下是一个简单的示例代码来实现消息队列功能: 将...
    99+
    2024-03-14
    Redis
  • redis怎么实现消息队列
    Redis可以通过以下几种方式实现消息队列:1. List数据结构:使用Redis的List数据结构实现简单的消息队列。生产者将消息...
    99+
    2023-09-14
    redis
  • MSMQ消息队列怎么实现
    这篇文章主要介绍了MSMQ消息队列怎么实现的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MSMQ消息队列怎么实现文章都会有所收获,下面我们一起来看看吧。一、引言Windows Communication Fou...
    99+
    2023-06-29
  • golang怎么实现消息队列
    在Golang中实现消息队列可以使用Golang的内置库和第三方库来实现。以下是两种常见的实现方式: 使用Golang内置的cha...
    99+
    2023-10-25
    golang
  • node消息队列怎么使用
    这篇文章主要介绍“node消息队列怎么使用”,在日常操作中,相信很多人在node消息队列怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”node消息队列怎么使用”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-07-05
  • Linux消息队列怎么使用
    在Linux中,消息队列是一种进程间通信的机制,用于在不同进程之间传递数据。下面是使用Linux消息队列的步骤: 包含头文件: ...
    99+
    2023-10-22
    Linux
  • 怎么使用redis消息队列
    要使用Redis作为消息队列,你需要按照以下步骤进行操作:1. 安装并启动Redis服务。2. 在你的应用程序中引入Redis的客户...
    99+
    2023-08-24
    redis
  • PHP怎么实现RabbitMQ消息列队
    这篇“PHP怎么实现RabbitMQ消息列队”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“PHP怎么实现RabbitMQ消息...
    99+
    2023-06-30
  • ThinkPHP怎么使用think-queue实现redis消息队列
    本篇内容主要讲解“ThinkPHP怎么使用think-queue实现redis消息队列”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ThinkPHP怎么使用think-queue实现redis消...
    99+
    2023-07-02
  • 如何使用redis实现消息队列
    使用redis实现消息队列的示例:redis的pubsub功能实现发布订阅模式,代码:import redisclass Task(object):def __init__(self):self.rcon = redis.StrictRed...
    99+
    2024-04-02
  • node中怎么使用消息队列
    这篇“node中怎么使用消息队列”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“node中怎...
    99+
    2024-04-02
  • Redis消息队列怎么实现秒杀
    要实现秒杀功能,可以使用Redis的消息队列来进行异步处理。下面是一种基本的实现方法:1. 准备工作:创建一个商品库存键值对,如"s...
    99+
    2023-10-11
    Redis
  • 使用PHP实现消息队列的开发
    随着现代互联网应用对高并发、高吞吐量和高可靠性的要求越来越高,消息队列作为一种异步解耦系统架构方式越来越被应用在互联网领域的各个方面。其原理是先将消息发送到消息队列中,等待异步消费,从而达到解耦的目的,提高系统的可扩展性与可维护性。在目前市...
    99+
    2023-05-25
    PHP 消息队列 开发
  • 怎么在springboot中用redis实现消息队列
    本篇内容主要讲解“怎么在springboot中用redis实现消息队列”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么在springboot中用redis实现消息队列”吧!准备阶段安装redi...
    99+
    2023-06-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作