gpt4 book ai didi

go - 如何高效关闭 channel ?

转载 作者:数据小太阳 更新时间:2023-10-29 03:04:29 25 4
gpt4 key购买 nike

我正在尝试做一些事情:

type Feed struct {
title, descr, link string
published time.Time
}
func main() {
ar := make([]Feed, 0)
for i := 0; i < 3; i++ {
f: = new(Feed)
// do some stuff with feed
ar = append(ar, *f)
}

ch := make(chan Feed, 3)

for _, i := range ar {
go process(i, ch)
}

r :=0
for i := range ch {
fmt.Println(i)
r++
if r == 3 {
close(ch)
}
}
}
func process(i Feed, ch chan Feed) {
// do some stuff
ch <- i
}

ar 似乎是不必要的,但如果将其删除,最后一个范围将是永远的。我做错了什么?

另一个问题是 - 这种使用 Go 例程的方式是否正确?

最佳答案

这是一个生产者-消费者类型的例子。我只使用 WaitGroup在这里,这样主 goroutine 就不会立即退出。从理论上讲,您的应用程序可以等待,或者同时做一些其他有趣的事情。

请注意,您还可以使用 c := make(chan(*Feed, n)) 来使用缓冲 channel 其中 n是您要缓冲的数字。请注意,在典型的生产者-消费者场景中,有时每个作业会分配大量资源。因此,根据您的需要,您可以只缓冲一些,或者全部缓冲。

没有缓冲 channel ,它充当 goroutine 之间的同步。生产者阻止在 c <-等待消费者的<- c移交给,因此每个例程中一次只有一个执行这些行。

编辑 我在打印“开始”之前添加了一个暂停,以使输出不那么同步。它以前总是输出:

created
started
created
started
...

https://play.golang.org/p/FmWqegr-CR

package main

import (
"fmt"
"math/rand"
"sync"
"time"
)

type Feed struct {
title, descr, link string
published time.Time
}

func CreateFeed() *Feed {
r := rand.Int() % 500
time.Sleep(1000 + time.Duration(r)*time.Millisecond)
fmt.Println("Feed created")
return &Feed{
published: time.Now(),
}
}

func UseFeed(f *Feed) {
time.Sleep(100 * time.Millisecond)
fmt.Println("Feed started")
time.Sleep(1600 * time.Millisecond)
fmt.Printf("Feed consumed: %s\n", f.published)
}

func main() {
numFeeds := 10

var wg sync.WaitGroup
wg.Add(10)

c := make(chan (*Feed))
for i := 0; i < numFeeds; i++ {
go func() { c <- CreateFeed() }()
}

for i := 0; i < numFeeds; i++ {
go func() {
f := <-c
UseFeed(f)
wg.Done()
}()
}

wg.Wait()
}

我希望这就是您要找的。

关于go - 如何高效关闭 channel ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44844654/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com