Как в языке 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)
}
}
Здесь три горутины выполняются параллельно, а канал используется для получения результатов от каждой из них.