golang channel是什么


本文摘自php中文网,作者(*-*)浩,侵删。

Go语言中的channel是实现goroutine间无锁通信的关键机制,他使得写多线程并发程序变得简单、灵活、触手可得。

Channel是Go中的一个核心类型,你可以把它看成一个管道,通过它并发核心单元就可以发送或者接收数据进行通讯(communication)。 (推荐学习:go)

它的操作符是箭头 <- 。

1

2

ch <- v    // 发送值v到Channel ch中

v := <-ch  // 从Channel ch中接收数据,并将数据赋值给v

channel结构

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

type hchan struct {

   qcount   uint           // total data in the queue 队列中存在的个数

   dataqsiz uint           // size of the circular queue buffer大小 实现看起来是个循环数组

   buf      unsafe.Pointer // points to an array of dataqsiz elements 数组指针

   elemsize uint16       //channel类型的大小

   closed   uint32      //channel是否关闭

   elemtype *_type // element type //channel 类型

   sendx    uint   // send index  //发送index

   recvx    uint   // receive index //接收index

   recvq    waitq  // list of recv waiters //接收链表 即读channel的goroutine

   sendq    waitq  // list of send waiters //发送链表 即写channel的goroutine

 

   // lock protects all fields in hchan, as well as several

   // fields in sudogs blocked on this channel.

   //

   // Do not change another G's status while holding this lock

   // (in particular, do not ready a G), as this can deadlock

   // with stack shrinking.

   lock mutex

}

以上就是golang channel是什么的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

go - options模式(函数式选项模式)

手把手教你实现golang跨平台编译

json序列化在golang中的应用

聊聊dubbo-go-proxy的zookeeperregistryload

golang gin可以做什么

聊聊dubbo-go-proxy的remotefilter

[系列] go - chan 通道

手撸golang 行为型设计模式 模板方法模式

gin快速入门

golang使用protobuf的方法详解

更多相关阅读请进入《golang》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...