为了账号安全,请及时绑定邮箱和手机立即绑定

发送通道后 Goroutine 未执行

发送通道后 Goroutine 未执行

Go
拉风的咖菲猫 2022-05-23 14:52:38
package mainimport (    "fmt"    "sync")// PUT functionfunc put(hashMap map[string](chan int), key string, value int, wg *sync.WaitGroup) {    defer wg.Done()    fmt.Printf("this is getting printed")    hashMap[key] <- value    fmt.Printf("this is not getting printed")    fmt.Printf("PUT sent %d\n", value)}func main() {    var value int    var key string    wg := &sync.WaitGroup{}    hashMap := make(map[string](chan int), 100)    key = "xyz"    value = 100    for i := 0; i < 5; i++ {        wg.Add(1)        go put(hashMap, key, value, wg)    }    wg.Wait()}put 函数中的最后两个打印语句没有被打印,我试图根据键将值放入映射中。以及在这种情况下如何关闭 hashMap。
查看完整描述

3 回答

?
九州编程

TA贡献1785条经验 获得超4个赞

  1. 您需要创建一个频道,例如hashMap[key] = make(chan int)

  2. 由于您不是从通道读取,因此需要缓冲通道才能使其工作:

 key := "xyz"

    hashMap[key] = make(chan int, 5)

试试下面的代码:


func put(hashMap map[string](chan int), key string, value int, wg *sync.WaitGroup) {

    hashMap[key] <- value

    fmt.Printf("PUT sent %d\n", value)

    wg.Done()

}

func main() {

    var wg sync.WaitGroup

    hashMap := map[string]chan int{}

    key := "xyz"

    hashMap[key] = make(chan int, 5)

    for i := 0; i < 5; i++ {

        wg.Add(1)

        go put(hashMap, key, 100, &wg)

    }

    wg.Wait()

}

输出:


PUT sent 100

PUT sent 100

PUT sent 100

PUT sent 100

PUT sent 100


查看完整回答
反对 回复 2022-05-23
?
缥缈止盈

TA贡献2041条经验 获得超4个赞

我解决问题的方法是:


// PUT function

func put(hashMap map[string](chan int), key string, value int, wg *sync.WaitGroup) {

    defer wg.Done()

    fmt.Printf("this is getting printed")

    hashMap[key] <- value // <-- nil problem

    fmt.Printf("this is not getting printed")

    fmt.Printf("PUT sent %d\n", value)

}

在函数中的这行代码hashMap[key] <- value中put,它不能接受参数中定义的value因为chan int是。nilput (hashMap map[string](chan int)


// PUT function

func put(hashMap map[string](chan int), cval chan int, key string, value int, wg *sync.WaitGroup) {

    defer wg.Done()

    fmt.Println("this is getting printed")

    cval <- value // put the value in chan int (cval) which is initialized

    hashMap[key] = cval // set the cval(chan int) to hashMap with key

    fmt.Println("this is not getting printed")

    fmt.Printf("PUT sent %s %d\n", key, value)

}


func main() {

    var value int

    wg := &sync.WaitGroup{}


    cval := make(chan int,100)

    hashMap := make(map[string](chan int), 100)


    value = 100

    for i := 0; i < 5; i++ {

        wg.Add(1)

        go put(hashMap, cval, fmt.Sprintf("key%d",i), value, wg)

    }

    wg.Wait()


    /* uncomment to test cval 

    close(cval)


    fmt.Println("Result:",<-hashMap["key2"])

    fmt.Println("Result:",<-hashMap["key1"])

    cval <- 88 // cannot send value to a close channel

    hashMap["key34"] = cval

    fmt.Println("Result:",<-hashMap["key1"])

    */



}

在我的代码示例中。我将cval缓冲通道 100 初始化为相同大小,hashMap并将 cval 作为put函数中的值传递。您只能关闭cval而不是 hashMap 本身。


查看完整回答
反对 回复 2022-05-23
?
翻阅古今

TA贡献1780条经验 获得超5个赞

此外,您的代码可以简化为此。为什么不必要地传递参数!一个额外的修改是我采用不同的值来让你更清楚地理解这个概念。


package main


import (

    "log"

    "sync"

)


func put(hash chan int, wg *sync.WaitGroup) {

    defer wg.Done()

    log.Println("Put sent: ", <-hash)

}


func main() {

    hashMap := map[string]chan int{}

    key := "xyz"

    var wg sync.WaitGroup

    hashMap[key] = make(chan int, 5)

    for i := 0; i < 5; i++ {

        value := i

        wg.Add(1)

        go func(val int) {

            hashMap[key] <- val

            put(hashMap[key], &wg)

        }(value)

    }

    wg.Wait()

}


查看完整回答
反对 回复 2022-05-23
  • 3 回答
  • 0 关注
  • 97 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信