Назад к вопросам
Positive Technologies
Junior — Middle
75
Каким образом реализована параллельность и конкуренция в языке 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 предоставляет простые и эффективные средства для написания конкурентных программ без сложного управления потоками.