duanmin0941 2017-08-16 04:15
浏览 2

关于goroutine并发的问题

I got some trouble about goroutine concurrent. In my expect, it should run asynchronously and print out almost at same time but what it really did was running with waiting

MyTestCode

package main

type batchD []string
var cBD = make(chan batchD, 6)

func main() {
    runtime.GOMAXPROCS(runtime.NumCPU())

    data := [][]string{}
    data = append(data, []string{"71", "40348270", "6", "win888e", "6", "1", "N", "127.0.0.1"})
    data = append(data, []string{"71", "40348270", "6", "win888e", "6", "1", "N", "127.0.0.1"})
    data = append(data, []string{"71", "40348270", "6", "win888e", "6", "1", "N", "127.0.0.1"})
    data = append(data, []string{"71", "129499244", "6", "win888e", "6", "1", "N", "127.0.0.1"})
    data = append(data, []string{"71", "40348270", "6", "win888e", "6", "1", "N", "127.0.0.1"})
    data = append(data, []string{"71", "40348270", "6", "win888e", "6", "1", "N", "127.0.0.1"})

    for k,v := range data {
        go func() {
            fmt.Println(k,v)
            //batchD{}.BatchDeposit(v[0],v[1],v[2],v[3],v[4],v[5],v[6],v[7])
            delay()
            cBD <- data[k]
        }()
        <-cBD
    }
}

func delay() {
    time.Sleep(1 * time.Second)
    t := Basic.NowTime("Taipei")
    fmt.Println(t)
}

Output I got

0 [71 40348270 6 win888e 6 1 N 127.0.0.1]  
2017-08-16 12:00:40  
1 [71 40348270 6 win888e 6 1 N 127.0.0.1]  
2017-08-16 12:00:41  
2 [71 40348270 6 win888e 6 1 N 127.0.0.1]  
2017-08-16 12:00:42  
3 [71 129499244 6 win888e 6 1 N 127.0.0.1]  
2017-08-16 12:00:43  
4 [71 40348270 6 win888e 6 1 N 127.0.0.1]  
2017-08-16 12:00:44  
5 [71 40348270 6 win888e 6 1 N 127.0.0.1]  
2017-08-16 12:00:45  

Output I Expected

0 [71 40348270 6 win888e 6 1 N 127.0.0.1]  
2017-08-16 12:00:40  
1 [71 40348270 6 win888e 6 1 N 127.0.0.1]  
2017-08-16 12:00:40  
2 [71 40348270 6 win888e 6 1 N 127.0.0.1]  
2017-08-16 12:00:40  
3 [71 129499244 6 win888e 6 1 N 127.0.0.1]  
2017-08-16 12:00:40  
4 [71 40348270 6 win888e 6 1 N 127.0.0.1]  
2017-08-16 12:00:40  
5 [71 40348270 6 win888e 6 1 N 127.0.0.1]  
2017-08-16 12:00:40  

Any suggestions or tips will helps. Thanks.

  • 写回答

1条回答 默认 最新

  • doujiu1447 2017-08-16 06:07
    关注

    Essentially, you have:

    var cBD = make(chan batchD, 6)
    for k := range data {
        go func() {
            time.Sleep(1 * time.Second)
            fmt.Println(time.Now().Format("2006-01-02 15:04:05"))
            cBD <- data[k]
        }()
        <-cBD
    }
    

    Each loop starts a goroutine. The loop then waits, via the channel receive <-cBD, until the goroutine sends to the channel, via cBD <- data[k], one second later. For example,

    2017-08-16 02:52:46
    2017-08-16 02:52:47
    2017-08-16 02:52:48
    2017-08-16 02:52:49
    2017-08-16 02:52:50
    2017-08-16 02:52:51
    
    评论

报告相同问题?

悬赏问题

  • ¥15 Oracle中如何从clob类型截取特定字符串后面的字符
  • ¥15 想通过pywinauto自动电机应用程序按钮,但是找不到应用程序按钮信息
  • ¥15 如何在炒股软件中,爬到我想看的日k线
  • ¥15 seatunnel 怎么配置Elasticsearch
  • ¥15 PSCAD安装问题 ERROR: Visual Studio 2013, 2015, 2017 or 2019 is not found in the system.
  • ¥15 (标签-MATLAB|关键词-多址)
  • ¥15 关于#MATLAB#的问题,如何解决?(相关搜索:信噪比,系统容量)
  • ¥500 52810做蓝牙接受端
  • ¥15 基于PLC的三轴机械手程序
  • ¥15 多址通信方式的抗噪声性能和系统容量对比