Back to questions
VK
Middle
1
Как можно управлять количеством потоков, используемых для выполнения горутин?
Companies where asked
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 влияет на параллельное выполнение горутин, но не ограничивает их количество — горутин может быть тысячи, они планируются на доступные потоки.