簡體   English   中英

對於范圍與靜態通道長度golang

[英]for range vs static channel length golang

我有一個通道,它從一個日志文件中解析事件,而另一個則用於同步。 為了我的測試,有8個事件。

使用for range語法時,我得到4個事件。 使用已知數字(8)時,我可以全部獲得。

func TestParserManyOpinit(t *testing.T) {
    ch := make(chan event.Event, 1000)
    done := make(chan bool)
    go parser.Parse("./test_data/many_opinit", ch, done)
    count := 0
    exp := 8
    evtList := []event.Event{}

    <-done
    close(ch)
    //This gets all the events
    for i := 0; i < 8; i++ {
            evtList = append(evtList, <-ch)
            count++
    }

    //This only gives me four
    //for range ch {
    //        evtList = append(evtList, <-ch)
    //        count++
    //}

    if count != exp || count != len(evtList) {
            t.Errorf("Not proper lenght, got %d, exp %d, evtList %d", count, exp, len(evtList))
    }

func Parse(filePath string, evtChan chan event.Event, done chan bool) {
    log.Info(fmt.Sprintf("(thread) Parsing file %s", filePath))
    file, err := os.Open(filePath)
    defer file.Close()

    if err != nil {
            log.Error("Cannot read file " + filePath)
    }
    count := 0
    scan := bufio.NewScanner(file)
    scan.Split(splitFunc)
    scan.Scan() //Skip log file header

    for scan.Scan() {
            text := scan.Text()
            text = strings.Trim(text, "\n")
            splitEvt := strings.Split(text, "\n")
            // Some parsing ...
            count++
            evtChan <- evt
    }

    fmt.Println("Done ", count) // gives 8
    done <- true
}

我必須丟失一些與通道上的for循環有關的東西。

我嘗試添加time.Sleepdone <- true time.Sleep部分之前。 它並沒有改變結果。

for range ,每個循環迭代都從通道讀取,並且您沒有使用讀取值。 因此,將丟棄一半的值。 它應該是:

for ev := range ch {
        evtList = append(evtList, ev)
        count++
}

為了實際利用循環迭代器中讀取的值。

圍棋范圍已在“ 圍棋旅”中進行了演示,並在圍棋規范中進行了詳細說明

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM