• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

go没有buffer的channel的调用顺序

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

 

第一种情况 第二种情况 第三种情况 第四种情况
rb rb sb sb
sb sb rb rb
se re re se
re se se re

显然: send begin 早于 send end, 

   recv begin 早于 recv end,

------------------------------------------------

  可得: 非buffer 的channel时: send begin 早于 recv end ---------这条也好理解。(没有buffer, 【接收完成】 肯定要晚于 【发送开始】)

                recv begin 早于 send end ----------这条稍微难理解一点,比较重要。(因为有buffer时, 【recv begin】 可能晚于 【send end】)

 

 

 

 

https://segmentfault.com/a/1190000008230146

https://www.jianshu.com/p/5e44168f47a3

 

------------------------------------------------------------------------------------------

第一种: r, s, s, r

 

 

package main

import (
//  "log"
  "time"
)

var a string
var c = make(chan int)
func main() {
  go func() { 
    a = "hello\n"
    print("recv begin..\n")
    <-c
    sum :=0
    for i := 0; i<1<<24; i++ {
      sum += i
    }
    print("recv end..\n")
  }()
  sum :=0
  for i := 0; i<1<<24; i++ {
    sum += i
  }
  print("send begin..\n")
  c <-12
  print("send end..\n")
  print(a)
  time.Sleep(time.Second*2)
}

----------------------------------------

  第二种情况 r, s, r, s

 

 

 package main
 
 import (
 //  "log"
   "time"
 )
 
 var a string
 var c = make(chan int)
 func main() {
   go func() { 
     a = "hello\n"
     print("recv begin..\n")
     <-c
     
     print("recv end..\n")
   }()
   sum :=0
   for i := 0; i<1<<24; i++ {
     sum += i
   }
   print("send begin..\n")
   c <-12
   sum =0
   for i := 0; i<1<<24; i++ {
     sum += i
   }
   print("send end..\n")
   print(a)
   time.Sleep(time.Second*2)
 }

---------------------------------------

  第三种情况:s, r, r, s

 

 

package main

import (
//  "log"
  "time"
)

var a string
var c = make(chan int)
func main() {
  go func() { 
    a = "hello\n"
    print("recv begin..\n")
    <-c
    
    print("recv end..\n")
  }()
  print("send begin..\n")
  c <-12
  sum :=0
  for i := 0; i<1<<24; i++ {
    sum += i
  } 
  print("send end..\n")
  print(a) 
  time.Sleep(time.Second*2)
} 
  

-----------------------------------------  

第四种情况: s, r, s, r

 

 

package main

import (
//  "log"
  "time"
)

var a string
var c = make(chan int)
func main() {
  go func() { 
    a = "hello\n"
    print("recv begin..\n")
    <-c
    sum :=0
    for i := 0; i<1<<24; i++ {
      sum += i
    }

    print("recv end..\n")
  }()
  print("send begin..\n")
  c <-12
    print("send end..\n")
  print(a)
  time.Sleep(time.Second*2)
}

  


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
[Go]获取当前时间戳秒/毫秒/纳秒 转成字符串string发布时间:2022-07-10
下一篇:
go初使用发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap