重构代码以惯用的方式使用单个通道
Refactor code to use a single channel in an idiomatic way
我有以下代码:
package main
import (
"fmt"
"time"
)
type Response struct {
Data string
Status int
}
func main() {
var rc [10]chan Response
for i := 0; i < 10; i++ {
rc[i] = make(chan Response)
}
var responses []Response
for i := 0; i < 10; i++ {
go func(c chan<- Response, n int) {
c <- GetData(n)
close(c)
}(rc[i], i)
}
for _, resp := range rc {
responses = append(responses, <-resp)
}
for _, item := range responses {
fmt.Printf("%+v\n", item)
}
}
func GetData(n int) Response {
time.Sleep(time.Second * 5)
return Response{
Data: "adfdafcssdf4343t43gf3jn4jknon239nwcwuincs",
Status: n,
}
}
你能告诉我实现相同目标但使用单一渠道的正确方法是什么吗?
由于您可以同时编写不同的数组和切片元素,因此您不需要任何通道。有关详细信息,请参阅 。
只需启动您的 goroutine,然后让它们写入适当的数组(或切片)元素。使用一个sync.WaitGroup
等待全部完成:
wg := &sync.WaitGroup{}
var responses [10]Response
for i := range responses {
wg.Add(1)
go func(n int) {
defer wg.Done()
responses[n] = GetData(n)
}(i)
}
wg.Wait()
for _, item := range responses {
fmt.Printf("%+v\n", item)
}
这与您的代码输出相同。在 Go Playground.
上试试
另见相关:
我有以下代码:
package main
import (
"fmt"
"time"
)
type Response struct {
Data string
Status int
}
func main() {
var rc [10]chan Response
for i := 0; i < 10; i++ {
rc[i] = make(chan Response)
}
var responses []Response
for i := 0; i < 10; i++ {
go func(c chan<- Response, n int) {
c <- GetData(n)
close(c)
}(rc[i], i)
}
for _, resp := range rc {
responses = append(responses, <-resp)
}
for _, item := range responses {
fmt.Printf("%+v\n", item)
}
}
func GetData(n int) Response {
time.Sleep(time.Second * 5)
return Response{
Data: "adfdafcssdf4343t43gf3jn4jknon239nwcwuincs",
Status: n,
}
}
你能告诉我实现相同目标但使用单一渠道的正确方法是什么吗?
由于您可以同时编写不同的数组和切片元素,因此您不需要任何通道。有关详细信息,请参阅
只需启动您的 goroutine,然后让它们写入适当的数组(或切片)元素。使用一个sync.WaitGroup
等待全部完成:
wg := &sync.WaitGroup{}
var responses [10]Response
for i := range responses {
wg.Add(1)
go func(n int) {
defer wg.Done()
responses[n] = GetData(n)
}(i)
}
wg.Wait()
for _, item := range responses {
fmt.Printf("%+v\n", item)
}
这与您的代码输出相同。在 Go Playground.
上试试另见相关: