Codice rientrante: differenze tra le versioni
Contenuto cancellato Contenuto aggiunto
→Collegamenti esterni: + portale |
m →Esempi: tag source deprecati, replaced: <source lang= → <syntaxhighlight lang= (2), </source> → </syntaxhighlight> (2) |
||
| (9 versioni intermedie di 8 utenti non mostrate) | |||
Riga 1:
In [[informatica]], il codice di un [[Programma (informatica)|programma]] o di una [[subroutine|routine]] è detto '''rientrante''' se è progettato in modo che una singola copia del codice in memoria possa essere condivisa ed eseguita contemporaneamente e senza risultati inaspettati da utenti multipli o [[processo (informatica)|processi]] separati. La programmazione rientrante è vitale per molti sistemi [[multitasking]] (vedi [[thread-safe]]).
Affinché una routine o comunque una parte di codice sia rientrante deve soddisfare questi requisiti:
Riga 14:
Il kernel dei sistemi operativi [[Windows NT]] è completamente rientrante, a differenza di quello di [[Windows 9x]], le cui notevoli porzioni di codice a [[16 bit]] derivate da [[MS-DOS]] non sono rientranti. Pertanto l'accesso a codice di sistema a 16 bit in Windows 9x è regolato da una sezione critica globale, con il risultato che spesso il sistema operativo opera in maniera ''monotask''.
Le [[funzione ricorsiva|funzioni ricorsive]] dovrebbero essere sempre rientranti, sebbene, con le dovute cautele, sia possibile scrivere funzioni ricorsive non rientranti
== Esempi ==
Nel frammento di codice che segue, entrambe le funzioni <code>f()</code> e <code>g()</code> '''non''' sono rientranti.
<
int g_var = 1;
int f(){
g_var = g_var + 2;
return g_var;
}
int g(){
return f () + 2;
}
</syntaxhighlight>
La funzione <code>f()</code> dipende dalla [[variabile globale]] <code>g_var</code>; perciò, se due processi eseguono la funzione ed accedono a <code>g_var</code> simultaneamente, il risultato dipende dalle tempistiche di esecuzione. Perciò, <code>f()</code> non è rientrante. Neppure <code>g()</code> è rientrante, perché richiama <code>f()</code> che non è rientrante.
Riga 37 ⟶ 35:
Queste sono invece funzioni rientranti:
<
int f(int i){
return i + 2;
}
int g(int i){
return f(i) + 2;
}
</syntaxhighlight>
== Collegamenti esterni ==
Riga 53 ⟶ 49:
{{Portale|Informatica}}
[[Categoria:Programmazione concorrente]]
| |||