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

Как в языке Go реализована модель работы с конкурентностью и синхронизацией?

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

sobes.tech AI

В языке Go конкурентность реализована через легковесные потоки — горутины (goroutines). Горутины запускаются с помощью ключевого слова go и работают параллельно, при этом Go-рантайм самостоятельно управляет их планировкой.

Для синхронизации и обмена данными между горутинами используется несколько механизмов:

  • Каналы (channels) — позволяют безопасно передавать данные между горутинами, обеспечивая синхронизацию. Каналы можно считать очередями, которые блокируют отправителя, если канал полон, и получателя, если канал пуст.

  • Пакет sync — содержит примитивы синхронизации, такие как мьютексы (sync.Mutex), условные переменные (sync.Cond), группы ожидания (sync.WaitGroup) и другие.

Пример использования горутин и каналов:

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)
    }
}

Здесь три горутины выполняются параллельно, а канал используется для получения результатов от каждой из них.