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, не определено и указывает на, вероятно, неправильно разработанное приложение.
2017-09-15 | Linux |