激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Golang - golang中for循環遍歷channel時需要注意的問題詳解

golang中for循環遍歷channel時需要注意的問題詳解

2020-05-15 10:06xialeistudio Golang

這篇文章主要給大家介紹了關于golang中for循環遍歷channel時需要注意的問題的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。

前言

for循環是Go語言唯一的循環結構,最近在做一個基于RabbitMQ的應用,由于官方的qos沒有golang的版本,所以出了一點問題。

問題代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
_, ch, err := component.NewRabbitMQ()
if err != nil {
 panic(err)
}
if err := ch.Qos(10, 0, true); err != nil {
 panic(err)
}
msgs, err := ch.Consume("push", "", false, false, false, false, nil)
if err != nil {
 panic(err)
}
for m := range msgs {
 go func(d *amqp.Delivery) {
   defer func() { d.Ack(false) }
   // 處理消息
  }(&m)
 }

發現消費到10條消息,進程就退出了,但是exit code為0,表示系統是正常退出,由于做了日志記錄可以確定消費了10條,所以初步確定是qos相關問題。

排查過程

  • 首先是把d的tag打印出來,發現全部是一樣的,可以確定是重復的一條消息
  • 一開始想到可能是經典的go協程執行在for循環結束以后導致的,但是看我的代碼不屬于這種情況,有使用&m保證每一條消息都是不同循環傳入的。所以判斷可能是for循環的傳遞問題。
  • 確定方向之后開始寫了一個測試項目用來驗證我的想法是否正確。

測試代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
package main
import "fmt"
func main() {
 ch := make(chan int, 10)
 for i := 0; i < 10; i++ {
 ch <- i
 }
 close(ch)
 for v := range ch {
 fmt.Println(&v)
 }
}

執行輸出

?
1
2
3
4
5
6
7
8
9
10
0xc420086008
0xc420086008
0xc420086008
0xc420086008
0xc420086008
0xc420086008
0xc420086008
0xc420086008
0xc420086008
0xc420086008

到這里才煥然大悟,for循環中,如果循環變量不是指針,那么每次的變量是同一個,不過值變了。,所以上例中的RabbitMQ go協程消費消息那里,需要直接傳遞值而不是指針,經過測試之后發現,問題確實解決了。

題外話

測試代碼那里,如果不close掉channel是會發生死鎖的,原因是 當for循環讀完channel的10個值之后會繼續嘗試讀取下一個,而由于channel為空又沒關閉,會一直阻塞形成死鎖

TOOD

研究RabbitMQ Consumer部分的源碼來看看消費channel被關閉的問題。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。

原文鏈接:https://www.ddhigh.com/2018/04/05/golang-for-over-channels.html

延伸 · 閱讀

精彩推薦
  • Golanggolang 通過ssh代理連接mysql的操作

    golang 通過ssh代理連接mysql的操作

    這篇文章主要介紹了golang 通過ssh代理連接mysql的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    a165861639710342021-03-08
  • GolangGolang通脈之數據類型詳情

    Golang通脈之數據類型詳情

    這篇文章主要介紹了Golang通脈之數據類型,在編程語言中標識符就是定義的具有某種意義的詞,比如變量名、常量名、函數名等等,Go語言中標識符允許由...

    4272021-11-24
  • Golanggo日志系統logrus顯示文件和行號的操作

    go日志系統logrus顯示文件和行號的操作

    這篇文章主要介紹了go日志系統logrus顯示文件和行號的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    SmallQinYan12302021-02-02
  • Golanggolang如何使用struct的tag屬性的詳細介紹

    golang如何使用struct的tag屬性的詳細介紹

    這篇文章主要介紹了golang如何使用struct的tag屬性的詳細介紹,從例子說起,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看...

    Go語言中文網11352020-05-21
  • GolangGolang中Bit數組的實現方式

    Golang中Bit數組的實現方式

    這篇文章主要介紹了Golang中Bit數組的實現方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    天易獨尊11682021-06-09
  • Golanggolang的httpserver優雅重啟方法詳解

    golang的httpserver優雅重啟方法詳解

    這篇文章主要給大家介紹了關于golang的httpserver優雅重啟的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,...

    helight2992020-05-14
  • Golanggo語言制作端口掃描器

    go語言制作端口掃描器

    本文給大家分享的是使用go語言編寫的TCP端口掃描器,可以選擇IP范圍,掃描的端口,以及多線程,有需要的小伙伴可以參考下。 ...

    腳本之家3642020-04-25
  • Golanggolang json.Marshal 特殊html字符被轉義的解決方法

    golang json.Marshal 特殊html字符被轉義的解決方法

    今天小編就為大家分享一篇golang json.Marshal 特殊html字符被轉義的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧 ...

    李浩的life12792020-05-27
主站蜘蛛池模板: 国产一级毛片高清视频完整版 | 黄色a级片免费观看 | 娇妻被各种姿势c到高潮小说 | 欧美日韩一区,二区,三区,久久精品 | 香蕉黄色网 | 欧美精品日日鲁夜夜添 | 亚洲精品a级 | 日韩精品一区二区三区中文 | 久久亚洲第一 | 斗罗破苍穹在线观看免费完整观看 | 久久久久久久久久久久久久av | 国产精品视频免费网站 | 久久99免费观看 | 成人免费淫片视频观 | 久久国产乱子伦精品 | 日韩av片在线免费观看 | 黄色片免费看网站 | 久久精品亚洲精品国产欧美kt∨ | 成人免费区| 看片一区二区三区 | 国产亚洲欧美日韩高清 | 久草在线综合 | 最近国产中文字幕 | 视频一区 中文字幕 | 精品国产一区二区三区免费 | 一级在线观看视频 | vidz 98hd | 国产91在线播放九色 | 色欲香天天天综合网站 | 欧美在线观看视频一区 | 毛片在线播放视频 | av在线看网站 | 久久久日韩精品一区二区三区 | av电影网站在线观看 | 美女视频黄视大全视频免费网址 | 色悠悠久久久久 | 久久精品视频国产 | avlululu| 国产一区二区三区四区五区精品 | 国产成人精品一区二区视频免费 | 精品国产一区在线观看 |