Sobes.tech
Back to questions
Middle
1

Как можно управлять количеством потоков, используемых для выполнения горутин?

Companies where asked
VKVK

Answer from AI

sobes.tech AI

В Go количество потоков ОС, используемых для выполнения горутин, управляется с помощью функции runtime.GOMAXPROCS(n). Эта функция задаёт максимальное количество операционных системных потоков, которые могут одновременно выполнять пользовательский код Go.

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

Пример:

package main

import (
    "fmt"
    "runtime"
)

func main() {
    fmt.Println("Default GOMAXPROCS:", runtime.GOMAXPROCS(0)) // Получить текущее значение
    runtime.GOMAXPROCS(2) // Установить максимум в 2 потока
    fmt.Println("Updated GOMAXPROCS:", runtime.GOMAXPROCS(0))
}

Важно понимать, что GOMAXPROCS влияет на параллельное выполнение горутин, но не ограничивает их количество — горутин может быть тысячи, они планируются на доступные потоки.