Назад к вопросам
Junior — Middle
90
Как реализуется конкуренция, асинхронность и параллельность в языке Go?
Ответ от нейросети
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 предоставляет простые и эффективные средства для работы с конкурентностью и параллельностью.