iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Go语言如何实现带缓冲的通道
  • 242
分享到

Go语言如何实现带缓冲的通道

2023-06-14 21:06:14 242人浏览 薄情痞子
摘要

这篇文章主要介绍Go语言如何实现带缓冲的通道,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!什么是gogo是golang的简称,golang 是Google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的编程

这篇文章主要介绍Go语言如何实现带缓冲的通道,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

什么是go

go是golang的简称,golang 是Google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的编程语言,其语法与 C语言相近,但并不包括如枚举、异常处理、继承、泛型、断言、虚函数等功能。

Go语言中有缓冲的通道(buffered channel)是一种在被接收前能存储一个或者多个值的通道。这种类型的通道并不强制要求 goroutine 之间必须同时完成发送和接收。通道会阻塞发送和接收动作的条件也会不同。只有在通道中没有要接收的值时,接收动作才会阻塞。只有在通道没有可用缓冲区容纳被发送的值时,发送动作才会阻塞。

这导致有缓冲的通道和无缓冲的通道之间的一个很大的不同:无缓冲的通道保证进行发送和接收的 goroutine 会在同一时间进行数据交换;有缓冲的通道没有这种保证。

在无缓冲通道的基础上,为通道增加一个有限大小的存储空间形成带缓冲通道。带缓冲通道在发送时无需等待接收方接收即可完成发送过程,并且不会发生阻塞,只有当存储空间满时才会发生阻塞。同理,如果缓冲通道中有数据,接收时将不会发生阻塞,直到通道中没有数据可读时,通道将会再度阻塞。

无缓冲通道保证收发过程同步。无缓冲收发过程类似于快递员给你电话让你下楼取快递,整个递交快递的过程是同步发生的,你和快递员不见不散。但这样做快递员就必须等待所有人下楼完成操作后才能完成所有投递工作。如果快递员将快递放入快递柜中,并通知用户来取,快递员和用户就成了异步收发过程,效率可以有明显的提升。带缓冲的通道就是这样的一个“快递柜”。

创建带缓冲通道

如何创建带缓冲的通道呢?参见如下代码:

通道实例 := make(chan 通道类型, 缓冲大小)

  • 通道类型:和无缓冲通道用法一致,影响通道发送和接收的数据类型。

  • 缓冲大小:决定通道最多可以保存的元素数量。

  • 通道实例:被创建出的通道实例。

下面通过一个例子中来理解带缓冲通道的用法,参见下面的代码:

package mainimport "fmt"func main() {    // 创建一个3个元素缓冲大小的整型通道    ch := make(chan int, 3)    // 查看当前通道的大小    fmt.Println(len(ch))    // 发送3个整型元素到通道    ch <- 1    ch <- 2    ch <- 3    // 查看当前通道的大小    fmt.Println(len(ch))}

代码输出如下:
0
3

代码说明如下:

  • 第 8 行,创建一个带有 3 个元素缓冲大小的整型类型的通道。

  • 第 11 行,查看当前通道的大小。带缓冲的通道在创建完成时,内部的元素是空的,因此使用 len() 获取到的返回值为 0。

  • 第 14~16 行,发送 3 个整型元素到通道。因为使用了缓冲通道。即便没有 goroutine 接收,发送者也不会发生阻塞。

  • 第 19 行,由于填充了 3 个通道,此时的通道长度变为 3。

阻塞条件

带缓冲通道在很多特性上和无缓冲通道是类似的。无缓冲通道可以看作是长度永远为 0 的带缓冲通道。因此根据这个特性,带缓冲通道在下面列举的情况下依然会发生阻塞:

  • 带缓冲通道被填满时,尝试再次发送数据时发生阻塞。

  • 带缓冲通道为空时,尝试接收数据时发生阻塞。

为什么Go语言对通道要限制长度而不提供无限长度的通道?

我们知道通道(channel)是在两个 goroutine 间通信的桥梁。使用 goroutine 的代码必然有一方提供数据,一方消费数据。当提供数据一方的数据供给速度大于消费方的数据处理速度时,如果通道不限制长度,那么内存将不断膨胀直到应用崩溃。因此,限制通道的长度有利于约束数据提供方的供给速度,供给数据量必须在消费方处理量+通道长度的范围内,才能正常地处理数据。

以上是“Go语言如何实现带缓冲的通道”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网精选频道!

--结束END--

本文标题: Go语言如何实现带缓冲的通道

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

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

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Go语言带缓冲的通道实现
    Go语言中有缓冲的通道(buffered channel)是一种在被接收前能存储一个或者多个值的通道。这种类型的通道并不强制要求 goroutine 之间必须同时完成发送和接收...
    99+
    2022-06-07
    GO 缓冲 go语言
  • Go语言如何实现带缓冲的通道
    这篇文章主要介绍Go语言如何实现带缓冲的通道,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!什么是gogo是golang的简称,golang 是Google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的编程...
    99+
    2023-06-14
  • Go语言通道之缓冲通道
    前文为大家讲解了Go语言通道之无缓冲通道 有缓冲的通道相比于无缓冲通道,多了一个缓存的功能,如下图描述的一样: 从图上可以明显看到和无缓冲通道的区别,无缓冲必须两个Goroutin...
    99+
    2022-11-13
  • Go语言通道之无缓冲通道
    一、通道是什么? 其实无论是原子函数还是共享锁都是通过共享内存的方式进行的同步、效率一般不高,而Go语言中则使用了通道,它是一种通过传递信息的方式进行数据同步,通过发送和接收需要共享...
    99+
    2022-11-13
  • Go语言通道之缓冲通道实例分析
    这篇“Go语言通道之缓冲通道实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Go语言通道之缓冲通道实例分析”文章吧。有...
    99+
    2023-07-02
  • Go语言通道之无缓冲通道实例分析
    这篇文章主要讲解了“Go语言通道之无缓冲通道实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Go语言通道之无缓冲通道实例分析”吧!一、通道是什么?其实无论是原子函数还是共享锁都是通过共...
    99+
    2023-07-02
  • Go语言单向通道如何实现
    今天小编给大家分享一下Go语言单向通道如何实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Go语言的类型系统提供了单方向的...
    99+
    2023-07-05
  • Go语言单向通道的实现
    目录单向通道的声明格式单向通道的使用例子 time包中的单向通道关闭 channelGo语言的类型系统提供了单方向的 channel 类型,顾名思义,单向 channel ...
    99+
    2023-05-14
    Go语言单向通道 Go单行道
  • 深入理解Go语言文档中的io.CopyBuffer函数实现带缓冲的文件复制
    Go语言的标准库中提供了很多IO操作相关的函数,其中有一个io.CopyBuffer函数可以实现带缓冲的文件复制。在本文中,我们将深入理解io.CopyBuffer函数的实现原理,并提供具体代码示例。一、函数介绍io.CopyBuffer函...
    99+
    2023-11-03
    Go语言 文件复制 ioCopyBuffer
  • Go语言使用goroutine及通道实现并发详解
    目录使用通道接收数据阻塞接收数据非阻塞接收数据接收任意数据,忽略掉接收的数据循环接收数据使用通道接收数据 在上一篇文章中介绍了通道以及使用通道发送数据,本篇接着了解通道的基本内容,如...
    99+
    2022-11-11
  • GO语言中通道和sync包如何使用
    这篇文章主要讲解了“GO语言中通道和sync包如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“GO语言中通道和sync包如何使用”吧!GO通道和 sync 包的分享我们一起回顾一下上次...
    99+
    2023-07-05
  • Go 语言中,如何实现同步缓存?
    在 Go 语言中,实现同步缓存是一项非常常见的任务。在这篇文章中,我们将介绍如何使用 Go 语言的 sync 包实现同步缓存。 缓存是一个用于存储临时数据的区域,可以让应用程序更快地访问和操作数据。在许多应用程序中,缓存被广泛使用,以提高性...
    99+
    2023-06-28
    关键字 同步 缓存
  • Go语言如何实现LeetCode缓存响应?
    在LeetCode上提交代码时,我们通常需要等待一段时间才能获得响应,这是因为LeetCode服务器需要编译和运行我们的代码。这个过程可能会非常耗时,如果我们频繁提交同样的代码,那么等待时间就会变得很长。 为了解决这个问题,我们可以使用缓...
    99+
    2023-09-14
    leetcode 缓存 响应
  • java中NIO通道和缓冲区是如何工作的
    这篇文章将为大家详细讲解有关java中NIO通道和缓冲区是如何工作的,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。通道 和 缓冲区 是 NIO 中的核心对象,几乎在每一个 I/O 操作中都要使用它们。通道...
    99+
    2023-06-17
  • 如何用Go语言和Redis实现数据缓存
    如何用Go语言和Redis实现数据缓存随着互联网应用的迅速发展,数据缓存成为提高系统性能和响应速度的重要手段之一。而Go语言作为一门高效、可靠的编程语言,搭配Redis这个高性能的缓存数据库,可以实现快速的数据缓存。本文将介绍如何使用Go语...
    99+
    2023-10-27
    Go语言 redis 数据缓存
  • 如何使用GO语言实现高效的响应缓存?
    随着Web应用程序的发展,缓存已经成为了提高应用性能的重要手段之一。在Web开发中,缓存是指将一些需要频繁访问的数据或计算结果存储在内存或磁盘中,以便下次访问时能够更快地获取到数据或计算结果。在实际的应用场景中,缓存可以用来加快响应速度、...
    99+
    2023-10-29
    响应 教程 缓存
  • 如何在Go语言中实现高效的并发缓存?
    在计算机科学中,缓存是一种常见的技术,它用于存储计算机系统中频繁访问的数据,以便快速访问。在高并发系统中,缓存可以提高系统的性能和响应速度。在本文中,我们将介绍如何在Go语言中实现高效的并发缓存。 一、并发缓存的需求 在高并发系统中,缓存...
    99+
    2023-06-06
    数组 并发 缓存
  • 如何在Go语言中实现路由的请求缓存
    如何在Go语言中实现路由的请求缓存在Web开发中,路由是一个非常重要的概念,用于将客户端请求映射到相应的处理程序。在高并发的情况下,频繁地处理请求可能会导致服务器性能下降。为了减轻服务器的负载和提高响应速度,可以对路由的请求进行缓存。在Go...
    99+
    2023-12-17
    Go语言 路由 请求缓存
  • 深入理解Go语言文档中的io.Pipe函数实现管道通信
    深入理解Go语言文档中的io.Pipe函数实现管道通信,需要具体代码示例引言:在Go语言中,通过io.Pipe函数可以方便地实现管道通信。本文将深入探讨io.Pipe函数的使用方法,并通过具体的代码示例来展示其功能和使用场景。一、io.Pi...
    99+
    2023-11-04
    管道通信 关键词:Go语言 ioPipe
  • go语言如何实现即时通讯聊天室
    本文小编为大家详细介绍“go语言如何实现即时通讯聊天室”,内容详细,步骤清晰,细节处理妥当,希望这篇“go语言如何实现即时通讯聊天室”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。实现的功能:公聊,私聊,修改用户名...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作