登录
首页 >  Golang >  Go问答

为什么只打印了不到20条问候语?

来源:stackoverflow

时间:2024-02-08 20:45:16 200浏览 收藏

各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题《为什么只打印了不到20条问候语?》,很明显是关于Golang的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很不错的话,欢迎各位多多点评和分享!

问题内容

我正在学习 golang,并且很难理解为什么这没有打印出 20 条问候语,即使我调用该函数两次,每次 10 次。

package main

import (
    "log"
    "math/rand"
    "time"
)

func SayGreetings(greeting string, times int) {
    for i := 0; i < times; i++ {
        log.Println(greeting)
        d := time.Second * time.Duration(rand.Intn(5)) / 2
        time.Sleep(d) // sleep for 0 to 2.5 seconds
    }
}

func main() {
    rand.Seed(time.Now().UnixNano())
    log.SetFlags(0)
    go SayGreetings("hi!", 10)
    go SayGreetings("hello!", 10)
    time.Sleep(2 * time.Second)
}

正确答案


解释起来非常简单。您使用 go 关键字调用 saygreetings 两次,这会导致 saygreetings 函数两次并发执行。最后,您不必等到两个函数都完成!您的代码在调用这两个函数后仅等待 2 秒,每个函数等待超过两秒。 因此,您要么增加 main 中的等待时间,要么等到两个函数完成

您的问题类似于 Wait for concurrent workers to finish before exiting

  1. 将 main 中的睡眠时间增加到 time.sleep(20 *time.second)
package main

import (
    "log"
    "math/rand"
    "time"
)

func SayGreetings(greeting string, times int) {
    for i := 0; i < times; i++ {
        log.Println(greeting)
        d := time.Second * time.Duration(rand.Intn(5)) / 2
        time.Sleep(d) // sleep for 0 to 2.5 seconds
    }
}

func main() {
    rand.Seed(time.Now().UnixNano())
    log.SetFlags(0)
    go SayGreetings("hi!", 10)
    go SayGreetings("hello!", 10)
    time.Sleep(20 * time.Second)
}

Output:
======
hi!
hi!
hello!
hello!
hi!
hello!
hi!
hello!
hello!
hi!
hello!
hi!
hi!
hello!
hello!
hello!
hi!
hello!
hi!
hi!

终于介绍完啦!小伙伴们,这篇关于《为什么只打印了不到20条问候语?》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

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