Back to questions
Junior — Middle
82
Каким образом реализуется управление конкурирующими потоками или процессами в программе?
Companies where asked
Цифровая Эволюция
Answer from AI
sobes.tech AI
В Go управление конкурирующими потоками (горутинами) реализуется с помощью встроенных примитивов:
- Горутинки (goroutines) — легковесные потоки, которые запускаются с помощью ключевого слова
go. - Каналы (channels) — используются для безопасного обмена данными между горутинами и синхронизации.
Пример управления конкурентностью:
package main
import (
"fmt"
"time"
)
func worker(id int, jobs <-chan int, results chan<- int) {
for j := range jobs {
fmt.Printf("Worker %d processing job %d\n", id, j)
time.Sleep(time.Second) // имитация работы
results <- j * 2
}
}
func main() {
jobs := make(chan int, 5)
results := make(chan int, 5)
for w := 1; w <= 3; w++ {
go worker(w, jobs, results)
}
for j := 1; j <= 5; j++ {
jobs <- j
}
close(jobs)
for a := 1; a <= 5; a++ {
fmt.Println("Result:", <-results)
}
}
Таким образом, управление конкуренцией в Go строится на простых и мощных примитивах, позволяющих писать безопасный и эффективный параллельный код.