Shortest Job First (SJF): esempio preventivo e non preventivo

Che cos'รจ la pianificazione del lavoro piรน breve?

Il lavoro piรน corto per primo (SJF) รจ un algoritmo in cui il processo con il tempo di esecuzione piรน breve viene scelto per l'esecuzione successiva. Questo metodo di pianificazione puรฒ essere preventivo o non preventivo. Riduce significativamente il tempo medio di attesa per altri processi in attesa di esecuzione. La forma completa di SJF รจ Shortest Job First.

Esistono fondamentalmente due tipi di metodi SJF:

  • SJF non preventivo
  • SJF preventivo

Caratteristiche della pianificazione SJF

  • รˆ associato a ciascun lavoro come unitร  di tempo da completare.
  • Questo metodo dell'algoritmo รจ utile per l'elaborazione di tipo batch, dove l'attesa del completamento dei lavori non รจ fondamentale.
  • Puรฒ migliorare la produttivitร  del processo garantendo che i lavori piรน brevi vengano eseguiti per primi, quindi possibilmente con tempi di consegna brevi.
  • Migliora la produzione lavorativa offrendo lavori piรน brevi, che dovrebbero essere eseguiti per primi, e che nella maggior parte dei casi hanno tempi di consegna piรน brevi.

SJF non preventivo

Nella pianificazione non preventiva, una volta assegnato il ciclo della CPU al processo, il processo lo mantiene finchรฉ non raggiunge uno stato di attesa o termina.

Si considerino i seguenti cinque processi, ciascuno dotato di un proprio tempo di burst e di un proprio tempo di arrivo.

Coda di elaborazione Tempo di scoppio Orario di arrivo
P1 6 2
P2 2 5
P3 8 1
P4 3 0
P5 4 4

Passo 0) Al tempo=0, P4 arriva e inizia l'esecuzione.

SJF non preventivo

Passo 1) Al tempo = 1, arriva il processo P3. Ma P4 necessita ancora di 2 unitร  di esecuzione per essere completata. Continuerร  l'esecuzione.

SJF non preventivo

Passo 2) Al tempo =2, il processo P1 arriva e viene aggiunto alla coda di attesa. P4 continuerร  l'esecuzione.

SJF non preventivo

Passo 3) Al tempo = 3, il processo P4 terminerร  la sua esecuzione. Viene confrontato il tempo di burst di P3 e P1. Il processo P1 viene eseguito perchรฉ il suo tempo di burst รจ inferiore rispetto a P3.

SJF non preventivo

Passo 4) Al tempo = 4, il processo P5 arriva e viene aggiunto alla coda di attesa. P1 continuerร  l'esecuzione.

SJF non preventivo

Passo 5) Al tempo = 5, il processo P2 arriva e viene aggiunto alla coda di attesa. P1 continuerร  l'esecuzione.

SJF non preventivo

Passo 6) Al tempo = 9, il processo P1 terminerร  la sua esecuzione. Viene confrontato il tempo di burst di P3, P5 e P2. Il processo P2 viene eseguito perchรฉ il suo tempo di burst รจ il piรน basso.

SJF non preventivo

Passo 7) All'istante=10, P2 รจ in esecuzione e P3 e P5 sono in coda di attesa.

SJF non preventivo

Passo 8) Al tempo = 11, il processo P2 terminerร  la sua esecuzione. Viene confrontato il tempo di burst di P3 e P5. Il processo P5 viene eseguito perchรฉ il suo tempo di burst รจ inferiore.

SJF non preventivo

Passo 9) Al tempo = 15, il processo P5 terminerร  la sua esecuzione.

SJF non preventivo

Passo 10) Al tempo = 23, il processo P3 terminerร  la sua esecuzione.

SJF non preventivo

Passo 11) Calcoliamo il tempo medio di attesa per l'esempio sopra.

Wait time 
P4= 0-0=0
P1=  3-2=1
P2= 9-5=4
P5= 11-4=7
P3= 15-1=14
Average Waiting Time= 0+1+4+7+14/5 = 26/5 = 5.2

SJF preventivo

Nella pianificazione preventiva SJF, i lavori vengono inseriti nella coda di preparazione non appena arrivano. Inizia l'esecuzione un processo con il tempo di burst piรน breve. Se arriva un processo con un tempo di burst ancora piรน breve, il processo corrente viene rimosso o interrotto dall'esecuzione e al lavoro piรน breve viene assegnato il ciclo della CPU.

Consideriamo i seguenti cinque processi:

Coda di elaborazione Tempo di scoppio Orario di arrivo
P1 6 2
P2 2 5
P3 8 1
P4 3 0
P5 4 4

Passo 0) Al tempo=0, P4 arriva e inizia l'esecuzione.

Coda di elaborazione Tempo di scoppio Orario di arrivo
P1 6 2
P2 2 5
P3 8 1
P4 3 0
P5 4 4

SJF preventivo

Passo 1) Al tempo = 1, arriva il processo P3. Ma P4 ha un tempo di burst piรน breve. Continuerร  l'esecuzione.

SJF preventivo

Passo 2) Al tempo = 2, il processo P1 arriva con tempo di burst = 6. Il tempo di burst รจ maggiore di quello di P4. Pertanto, P4 continuerร  l'esecuzione.

SJF preventivo

Passo 3) Al tempo = 3, il processo P4 terminerร  la sua esecuzione. Viene confrontato il tempo di burst di P3 e P1. Il processo P1 viene eseguito perchรฉ il suo tempo di burst รจ inferiore.

SJF preventivo

Passo 4) Al tempo = 4 arriverร  il processo P5. Viene confrontato il tempo di burst di P3, P5 e P1. Il processo P5 viene eseguito perchรฉ il suo tempo di burst รจ piรน basso. Il processo P1 รจ anticipato.

Coda di elaborazione Tempo di scoppio Orario di arrivo
P1 Ne restano 5 su 6 2
P2 2 5
P3 8 1
P4 3 0
P5 4 4

SJF preventivo

Passo 5) Al tempo = 5 arriverร  il processo P2. Viene confrontato il tempo di burst di P1, P2, P3 e P5. Il processo P2 viene eseguito perchรฉ il suo tempo di burst รจ minimo. Il processo P5 รจ anticipato.

Coda di elaborazione Tempo di scoppio Orario di arrivo
P1 Ne restano 5 su 6 2
P2 2 5
P3 8 1
P4 3 0
P5 Ne restano 3 su 4 4

SJF preventivo

Passo 6) All'istante =6, P2 รจ in esecuzione.

SJF preventivo

Passo 7) Al tempo =7, P2 termina la sua esecuzione. Viene confrontato il tempo di burst di P1, P3 e P5. Il processo P5 viene eseguito perchรฉ il suo tempo di burst รจ inferiore.

Coda di elaborazione Tempo di scoppio Orario di arrivo
P1 Ne restano 5 su 6 2
P2 2 5
P3 8 1
P4 3 0
P5 Ne restano 3 su 4 4

SJF preventivo

Passo 8) Al tempo =10, P5 terminerร  la sua esecuzione. Viene confrontato il tempo di burst di P1 e P3. Il processo P1 viene eseguito perchรฉ il suo tempo di burst รจ inferiore.

SJF preventivo

Passo 9) Al tempo =15, P1 termina la sua esecuzione. P3 รจ l'unico processo rimasto. Inizierร  l'esecuzione.

SJF preventivo

Passo 10) Al tempo =23, P3 termina la sua esecuzione.

SJF preventivo

Passo 11) Calcoliamo il tempo medio di attesa per l'esempio sopra.

Wait time 
P4= 0-0=0
P1=  (3-2) + 6 =7
P2= 5-5 = 0
P5= 4-4+2 =2
P3= 15-1 = 14
Average Waiting Time = 0+7+0+2+14/5 = 23/5 =4.6

Vantaggi dell'SJF

Ecco i vantaggi/pro dell'utilizzo del metodo SJF:

  • SJF viene spesso utilizzato per la pianificazione a lungo termine.
  • Riduce il tempo medio di attesa rispetto all'algoritmo FIFO (First in First Out).
  • Il metodo SJF fornisce il tempo di attesa medio piรน basso per un insieme specifico di processi.
  • รˆ appropriato per i lavori eseguiti in batch, dove i tempi di esecuzione sono noti in anticipo.
  • Per il sistema batch di pianificazione a lungo termine, รจ possibile ottenere una stima del tempo di burst dalla descrizione del lavoro.
  • Per la pianificazione a breve termine, dobbiamo prevedere il valore del prossimo burst time.
  • Probabilmente ottimale per quanto riguarda il tempo medio di consegna.

Svantaggi/contro di SJF

Ecco alcuni svantaggi/contro dell'algoritmo SJF:

  • Il tempo di completamento del lavoro deve essere noto in anticipo, ma รจ difficile da prevedere.
  • Viene spesso utilizzato in un sistema batch per la pianificazione a lungo termine.
  • SJF non puรฒ essere implementato per Programmazione della CPU per il breve termine. Ciรฒ รจ dovuto al fatto che non esiste un metodo specifico per prevedere la durata del prossimo burst della CPU.
  • Questo algoritmo puรฒ causare tempi di consegna molto lunghi o fame.
  • Richiede la conoscenza della durata di esecuzione di un processo o di un lavoro.
  • Porta alla fame che non riduce i tempi medi di consegna.
  • รˆ difficile conoscere la lunghezza della prossima richiesta della CPU.
  • Il tempo trascorso dovrebbe essere registrato, il che si traduce in un maggiore sovraccarico sul processore.

Sintesi

  • SJF รจ un algoritmo in cui il processo con il tempo di esecuzione piรน breve viene scelto per l'esecuzione successiva.
  • La pianificazione SJF รจ associata a ciascun lavoro come unitร  di tempo da completare.
  • Questo metodo dell'algoritmo รจ utile per l'elaborazione di tipo batch, dove l'attesa del completamento dei lavori non รจ fondamentale.
  • Esistono fondamentalmente due tipi di metodi SJF 1) SJF non preventivo e 2) SJF preventivo.
  • Nella pianificazione non preventiva, una volta assegnato il ciclo della CPU al processo, il processo lo mantiene finchรฉ non raggiunge uno stato di attesa o termina.
  • Nella pianificazione preventiva SJF, i lavori vengono inseriti nella coda di preparazione non appena arrivano.
  • Sebbene inizi un processo con un tempo di burst breve, il processo corrente viene rimosso o interrotto dall'esecuzione e il lavoro piรน breve viene eseguito per primo.
  • SJF viene spesso utilizzato per la pianificazione a lungo termine.
  • Riduce il tempo medio di attesa rispetto all'algoritmo FIFO (First in First Out).
  • Nella pianificazione SJF, il tempo di completamento del lavoro deve essere noto in anticipo, ma รจ difficile da prevedere.
  • SJF non puรฒ essere implementato per la pianificazione della CPU a breve termine. Ciรฒ รจ dovuto al fatto che non esiste un metodo specifico per prevedere la durata del prossimo burst della CPU.

Riassumi questo post con: