Sobes.tech
Back to questions
Junior — Middle
89

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

Answer from AI

sobes.tech AI

В Go конкуренция, асинхронность и параллельность реализуются с помощью горутин и каналов.

  • Горутины — это легковесные потоки, которые запускаются с помощью ключевого слова go. Они позволяют выполнять функции асинхронно и конкурировать за ресурсы.
  • Каналы используются для безопасного обмена данными между горутинами, обеспечивая синхронизацию и передачу сообщений.

Параллельность достигается за счет запуска нескольких горутин, которые могут выполняться одновременно на нескольких ядрах процессора, если задать GOMAXPROCS.

Пример:

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