登录
首页 >  Golang >  Go问答

为什么我的代码在尝试 Goroutines 后运行速度变慢?

来源:stackoverflow

时间:2024-04-03 13:54:35 450浏览 收藏

欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《为什么我的代码在尝试 Goroutines 后运行速度变慢?》,这篇文章主要讲到等等知识,如果你对Golang相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!

问题内容

我决定尝试弄清楚 goroutines 和通道。我创建了一个函数,它接受一个列表并向每个元素添加 10。然后我创建了另一个函数来尝试合并通道和 goroutine。当我对代码进行计时时,它运行得慢得多。我尝试做一些研究,但无法弄清楚任何事情。

这是我的频道代码:

package main

import ("fmt"
        "time")

func addTen(channel chan int) {
    channel <- 10 + <-channel
}

func listPlusTen(list []int) []int {
    channel := make(chan int)
    for i:= 0; i < len(list); i++ {
        go addTen(channel)
        channel <- list[i]
        list[i] = <-channel
    }
    return list
}

func main(){
    var size int
    list := make([]int, 0)
    fmt.Print("Enter the list size: ")
    fmt.Scanf("%d", &size)

    for i:=0; i <= size; i++ {
        list = append(list, i)
    }
    start := time.Now()
    list = listPlusTen(list)
    end := time.Now()
    fmt.Println(end.Sub(start)) 
}

解决方案


您正在向基线算法添加大量同步开销。您有 len(list) goroutine,它们都等待从公共通道读取。当您写入通道时,调度程序会选择其中一个 goroutine,该 goroutine 会加 10,然后写入通道,这会再次启用主 goroutine。在没有真正测量的情况下很难推测,但如果将 Goroutine 创建移到 for 循环之外,那么您将只有一个 Goroutine,从而减少调度程序开销。然而,与基线算法相比,这会更慢,因为每个操作都涉及两次同步和两次上下文切换,这比算法本身花费更多。

我对 go 例程有类似的经验,我在其中使用相同的函数发出 20 个 http 请求。

在简单循环中调用函数比使用等待组快得多

本篇关于《为什么我的代码在尝试 Goroutines 后运行速度变慢?》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

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