如何在3秒内打印出该Go代码?

问题描述

这是Go代码 https://www.intervue.io/sandbox-ILSCXZ6RR

func worker() chan int {
   ch := make(chan int)

   go func() {
      time.Sleep(3 * time.Second)
      ch <- 42
   }()

   return ch
}

func main() {
   timeStart := time.Now()

   _,_ = <-worker(),<-worker()

   println(int(time.Since(timeStart).Seconds())) // 3 or 6 ?
}

如何使它在3秒内执行而不是在6秒内执行?

解决方法

这需要6秒钟,因为您是从worker()返回的频道接收的,所以第二个worker()不能启动,直到从第一个收到一个值,这需要3秒钟。

您正在使用元组分配。 Spec: Assignments:

任务分两个阶段进行。首先,左侧的index expressionspointer indirections的操作数(包括selectors中的隐式指针间接寻址)和右侧的表达式均为evaluated in the usual order 。其次,分配是从左到右执行的。

还有Spec: Order of evaluation:

...在评估表达式,赋值或operandsreturn statement时,所有函数调用,方法调用和通信操作均按从左到右的词汇顺序进行评估

首先启动2个工作程序,然后然后从渠道接收消息,因此goroutine可以真正同时运行:

ch1,ch2 := worker(),worker()
_,_ = <-ch1,<-ch2

这样,输出将是(在Go Playground上尝试):

3
,

您还可以删除频道,因为您没有使用频道的结果,只需使用sync.WaitGroup

func worker(n int,wg *sync.WaitGroup) {
    defer wg.Done()
    time.Sleep(3 * time.Second)
    fmt.Println("done")
}

func main() {
    timeStart := time.Now()
    var wg sync.WaitGroup

    for i := 0; i <= 1; i++ {
        wg.Add(1)
        go worker(i,&wg)
    }
    wg.Wait()

    fmt.Println(int(time.Since(timeStart).Seconds())) // 3
}

以下是示例代码:https://play.golang.org/p/9_Ymx0tcHqS

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...