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

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

Компании, где спрашивали
Эрливидео
Самокат Тех
Positive TechnologiesPositive Technologies

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

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