Назад к вопросам
Junior — Middle
76
Насколько комфортно вам работать с функцией async.Map для асинхронных операций?
Ответ от нейросети
sobes.tech AI
В стандартной библиотеке Go нет функции async.Map, но есть похожие подходы для параллельной обработки с помощью горутин и каналов. Обычно для асинхронного применения функции к срезу используют горутины и sync.WaitGroup, чтобы запускать операции параллельно и ждать их завершения.
Пример реализации асинхронного Map:
func asyncMap(inputs []int, fn func(int) int) []int {
var wg sync.WaitGroup
results := make([]int, len(inputs))
for i, v := range inputs {
wg.Add(1)
go func(i, v int) {
defer wg.Done()
results[i] = fn(v)
}(i, v)
}
wg.Wait()
return results
}
// Использование
inputs := []int{1, 2, 3, 4}
outputs := asyncMap(inputs, func(x int) int { return x * 2 })
fmt.Println(outputs) // [2 4 6 8]
Такой подход позволяет эффективно распараллелить операции, но требует аккуратного управления синхронизацией и обработкой ошибок.