在Go语言中,可以使用goroutine和channel来解决并发任务并行执行的问题。
首先,使用关键字go来创建一个goroutine,将需要并发执行的任务放在其中。例如:
```go
go func() {
// 并发执行的任务
}()
```
然后,可以使用channel来传递数据和同步goroutine。创建一个channel,并使用<-符号将数据发送到channel中。例如:
```go
ch := make(chan int)
go func() {
// 并发执行的任务
ch <- result // 将结果发送到channel中
}()
```
可以使用range关键字来从channel中读取数据,进行处理。例如:
```go
for result := range ch {
// 处理结果
}
```
最后,可以使用sync包中的WaitGroup来等待所有goroutine执行完成。例如:
```go
var wg sync.WaitGroup
for i := 0; i < numTasks; i++ {
wg.Add(1)
go func() {
// 并发执行的任务
wg.Done()
}()
}
wg.Wait()
```
以上是Go语言中解决并发任务并行执行问题的基本思路。通过goroutine和channel的组合可以实现高效的并发编程。