PR_Sleep

Causes the current thread to yield for a specified amount of time.

Syntax

#include <prthread.h>

PRStatus PR_Sleep(PRIntervalTime ticks);

Parameter

PR_Sleep has the following parameter:

ticks

The number of ticks you want the thread to sleep for (see PRIntervalTime).

Returns

Calling PR_Sleep with a parameter equivalent to PR_INTERVAL_NO_TIMEOUT is an error and results in a PR_FAILURE error.

Description

PR_Sleep simply waits on a condition for the amount of time specified. If you set ticks to PR_INTERVAL_NO_WAIT, the thread yields.

If ticks is not PR_INTERVAL_NO_WAIT, PR_Sleep uses an existing lock, but has to create a new condition for this purpose. If you have already created such structures, it is more efficient to use them directly.

Calling PR_Sleep with the value of ticks set to PR_INTERVAL_NO_WAIT simply surrenders the processor to ready threads of the same priority. All other values of ticks cause PR_Sleep to block the calling thread for the specified interval.

Threads blocked in PR_Sleep are interruptible.