Sobes.tech
Назад к вопросам
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]

Такой подход позволяет эффективно распараллелить операции, но требует аккуратного управления синхронизацией и обработкой ошибок.