Compartilhar via


Comutadores de contexto

O agendador mantém uma fila de threads executáveis para cada nível de prioridade. Eles são conhecidos como threads prontos. Quando um processador fica disponível, o sistema executa um comutador de contexto . As etapas em uma opção de contexto são:

  1. Salve o contexto do thread que acabou de ser executado.
  2. Coloque o thread que acabou de ser executado no final da fila para sua prioridade.
  3. Localize a fila de prioridade mais alta que contém threads prontos.
  4. Remova o thread na cabeça da fila, carregue seu contexto e execute-o.

As seguintes classes de threads não são threads prontos.

  • Threads criados com o sinalizador CREATE_SUSPENDED
  • Threads interrompidos durante a execução com a função SuspendThread ou SwitchToThread
  • Threads aguardando uma entrada ou objeto de sincronização.

Até que os threads suspensos ou bloqueados fiquem prontos para serem executados, o agendador não alocará tempo de processador para eles, independentemente de sua prioridade.

Os motivos mais comuns para uma opção de contexto são:

  • A fatia de tempo decorrido.
  • Um thread com prioridade mais alta ficou pronto para ser executado.
  • Um thread em execução precisa esperar.

Quando um thread em execução precisa esperar, ele abre mão do restante de sua fatia de tempo.