登录
首页 >  Golang >  Go问答

如何实现Go代码在3秒内完成打印?

来源:stackoverflow

时间:2024-03-02 17:24:25 315浏览 收藏

哈喽!今天心血来潮给大家带来了《如何实现Go代码在3秒内完成打印?》,想必大家应该对Golang都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到,若是你正在学习Golang,千万别错过这篇文章~希望能帮助到你!

问题内容

这是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 秒内执行?


解决方案


由于您正在从 worker() 返回的通道接收数据,因此需要 6 秒,因此在收到第一个 worker() 的值之前,无法启动第二个 worker(),这需要 3 秒。

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

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

还有Spec: Order of evaluation:

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

先启动2个worker,然后从通道接收数据,这样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

好了,本文到此结束,带大家了解了《如何实现Go代码在3秒内完成打印?》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>