Sobes.tech
Назад к вопросам
Junior — Middle
74

Как реализована параллельная обработка и управление конкурентными задачами в Go?

Ответ от нейросети

sobes.tech AI

В Go параллельная обработка и управление конкурентными задачами реализованы через горутины (goroutines) и каналы (channels).

  • Горутины — это легковесные потоки, которые запускаются с помощью ключевого слова go. Они позволяют выполнять функции параллельно.

  • Каналы — это типизированные каналы для обмена данными между горутинами, обеспечивающие синхронизацию и безопасный обмен информацией.

Пример:

package main

import (
    "fmt"
    "time"
)

func worker(id int, ch chan string) {
    time.Sleep(time.Second)
    ch <- fmt.Sprintf("Worker %d done", id)
}

func main() {
    ch := make(chan string)
    for i := 1; i <= 3; i++ {
        go worker(i, ch)
    }
    for i := 1; i <= 3; i++ {
        msg := <-ch
        fmt.Println(msg)
    }
}

В этом примере три горутины выполняются параллельно, а канал используется для получения результатов.

Таким образом, Go предоставляет простые и мощные инструменты для конкурентного программирования без сложностей традиционных потоков.