Назад к вопросам
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 предоставляет простые и мощные инструменты для конкурентного программирования без сложностей традиционных потоков.