SCHED_YIELD(2) Руководство программиста Linux SCHED_YIELD(2)

ИМЯ

sched_yield - освободить процессор

ОБЗОР

#include <sched.h>

int sched_yield(void);

ОПИСАНИЕ

Вызов sched_yield() заставляет вызывающую нить освободить процессор. Нить перемещается в конец очереди согласно её статическому приоритету, и управление передаётся другой нити.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении sched_yield() возвращается 0. При ошибке возвращается -1, а значение errno устанавливается соответствующим образом.

ОШИБКИ

В Linux-реализации sched_yield() всегда завершается успешно.

СООТВЕТСТВИЕ СТАНДАРТАМ

POSIX.1-2001, POSIX.1-2008.

ЗАМЕЧАНИЯ

Если вызывающая нить единственная в списке с самым высоким приоритетом, то она продолжит выполняться после вызова sched_yield().

В системах POSIX, в которых доступен вызов sched_yield(), определён _POSIX_PRIORITY_SCHEDULING в <unistd.h>.

Оперативные вызовы sched_yield() могут улучшить производительность, давая другим нитям или процессам шанс поработать, когда (сильно) оспариваемые ресурсы (например, мьютексы) освобождаются вызывающим. Избегайте частых или нецелесообразных вызовов sched_yield() (например, когда ресурсы, необходимые других планируемым нитям, по-прежнему удерживаются вызывающим), так как это приводит к чрезмерному переключению контекстов, что ухудшит производительность системы.

Функция sched_yield() предназначена для использования с алгоритмами планирования реального времени (т. е., SCHED_FIFO или SCHED_RR). Использование sched_yield() с недерминированными алгоритмами планирования, такими как SCHED_OTHER, не определено и указывает на, вероятно, неправильно разработанное приложение.

СМОТРИТЕ ТАКЖЕ

sched(7)

2017-09-15 Linux