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

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

它的操作符是箭头 <- 。

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

channel结构

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}

更多相关文章

  1. golang中定义不定长数组的方法
  2. golang判断数组是否为空的方法
  3. golang如何删除数组中的元素
  4. golang如何判断数据类型
  5. golang数据类型有哪些
  6. golang数组与切片的区别是什么?
  7. golang数组和切片的区别是什么
  8. golang 如何类型转换
  9. go语言数据类型转换教程

随机推荐

  1. Android之所以不需要关闭后台运行程序 的
  2. Android拓展 lua实现类似按键精灵效果
  3. 【gravity】android:layout_gravity 和 a
  4. Android Java 网络 OS等笔试题 -- 全
  5. Android之adb
  6. 谷安: Andorid 的故事:完整的 Android 历
  7. Android全球开发者大会参后感
  8. Google放弃“不做恶”? 意欲垄断Android
  9. Android零基础入门第33节:Android事件处理
  10. Android与H5互调详细介绍