package main
import (
"context"
"fmt"
"sync"
"time"
)
func processTasks(ctx context.Context, tasks []string) {
var wg sync.WaitGroup
results := make(chan string, len(tasks))
for i, task := range tasks {
wg.Add(1)
go func(id int, taskName string) {
defer wg.Done()
// 为每个任务创建子context
taskCtx, cancel := context.WithTimeout(ctx, 2*time.Second)
defer cancel()
select {
case <-taskCtx.Done():
results <- fmt.Sprintf("任务 %d (%s): 被取消", id, taskName)
case <-time.After(1 * time.Second):
results <- fmt.Sprintf("任务 %d (%s): 完成", id, taskName)
}
}(i, task)
}
// 等待所有任务完成
go func() {
wg.Wait()
close(results)
}()
// 收集结果
for result := range results {
fmt.Println(result)
}
}
func main() {
ctx, cancel := context.WithTimeout(context.Background(), 3*time.Second)
defer cancel()
tasks := []string{"任务A", "任务B", "任务C", "任务D"}
processTasks(ctx, tasks)
}