欢迎各位小伙伴来到编程网,相聚于此都是缘哈哈哈!今天我给大家带来《为什么我的代码在尝试 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的相关知识,请关注编程网公众号!