Context Switches
The scheduler maintains a queue of executable threads for each priority level.
These are known as
ready threads. When a processor becomes available, the system performs a
context switch. The steps in a context switch are:
- Save the context of the thread that just finished executing.
- Place the thread that just finished executing at the end of the queue for its
priority.
- Find the highest priority queue that contains ready threads.
- Remove the thread at the head of the queue, load its context, and execute it.
The following classes of threads are not ready threads.
- Threads created with the CREATE_SUSPENDED flag
- Threads halted during execution with the SuspendThread or SwitchToThread function
- Threads waiting for a synchronization object or input.
Until threads that are suspended or blocked become ready to run, the scheduler
does not allocate any processor time to them, regardless of their priority.
The most common reasons for a context switch are:
- The time slice has elapsed.
- A thread with a higher priority has become ready to run.
- A running thread needs to wait.
When a running thread needs to wait, it relinquishes the remainder of its time
slice.
- Software for developers
-
Delphi Components
.Net Components
Software for Android Developers
- More information resources
-
MegaDetailed.Net
Unix Manual Pages
Delphi Examples
- Databases for Amazon shops developers
-
Amazon Categories Database
Browse Nodes Database