Funzioni in C++
Un problema reale complesso può essere in sotto-problemi più semplici. Ogni sotto-problema viene analizzato e risolto in modo indipendente dagli altri.
Questa metodologia di scomposizione di un problema in problemi più semplici è detta top-down.
L’analisi di un problema complesso avviene per raffinamenti successivi, si scompone cioè l’attività da svolgere in sotto-attività, che possono risultare a loro volta ulteriormente scomponibili. Questo processo è quindi ricorsivo: si procede nella scomposizione in attività sempre più semplici fino a giungere ad azioni elementari che, nel caso dello sviluppo del software, corrispondono alle singole istruzioni scritte nel linguaggio di programmazione scelto.
Ogni sotto-problema verrà quindi risolto da un singolo sotto-programma interagendo con gli altri senza dover conoscerne le attività svolte che hanno portato alla risoluzione del sotto-problema.
Un sotto-programma, identificato da un nome, è un insieme di istruzioni che viene invocato dal MAIN, il sotto-programma principale. L’esecuzione di un programma parte dalla prima istruzione contenuta nel MAIN. Ogni successiva istruzione viene eseguita in sequenza e quando incontra un’istruzione di chiamata CALL ad un sotto-programma, il MAIN sospende il proprio lavoro e demanda al sottoprogramma il compito di eseguire le proprie istruzioni prefissate. Quando il sotto-programma conclude il proprio lavoro, ritorna il comando al MAIN il quale prosegue nell’eseguire le proprie istruzioni a partire dalla prima istruzione successiva a quella della chiamata.
In realtà esiste una differenza fra procedura e funzione. Una procedura è un sotto-programma indipendente dagli altri che ha il solo compito di eseguire le proprie istruzioni necessarie a risolvere un particolare sotto-problema assegnatogli. Una funzione invece è un sotto-programma che svolge gli stessi compiti della procedura ma che in più restituisce al sotto-programma chiamante, per esempio il MAIN, il risultato della funzione stessa.
Le procedure e le funzioni fanno parte di un particolare paradigma di programmazione, che viene detto modulare. Questa metodologia di scomposizione del programma consente la creazione di moduli distinti ciascuno costituito da uno o più sotto-programmi offrendo numerosi vantaggi, tra i quali:
- Miglioramento della lettura del codice.
- Riutilizzo del codice nello stesso programma o in altri.
- Riduzione del tempo di sviluppo del software grazie al fatto che più sviluppatori possono lavorare contemporaneamente allo stesso progetto.
- Semplificazione delle attività di manutenzione del software.
Sotto-programmi in C++
Nel linguaggio C++ esiste solo il concetto di funzione, cioè un sottoprogramma che restituisce un valore. Per creare delle procedure bisogna gestire in modo particolare le funzioni, facendo in modo che non facciano ritornare nessun valore (VOID).
Una funzione ha la seguente struttura:
1 2 3 4 5 6 |
tipo_restituito nome_funzione (tipo1 par1, tipo2 par2, …) { //corpo del sotto-programma dichiarazioni di variabili (locali); istruzioni; return valore; } |
Dove:
- tipo_restituito indica il tipo (int, float, double, char, string, bool, etc)di risultato che la funzione restituisce.
- nome_funzione indica il nome assegnato alla funzione.
- corpo del sotto-programma costituito dalle dichiarazioni di variabili locali e istruzioni atte a risolvere il sotto-problema assegnatogli;
tra le varie istruzioni deve essere presente come ultima istruzione quella che consente alla funzione stessa di restituire un risultato al MAIN:
return risultato;
dove risultato rappresenta una variabile che assume il valore finale dell’elaborazione (il risultato).
Per realizzare una procedura basterà omettere l’istruzione “return risultato”, in modo che non restituisca nessun valore, e come tipo di dato restituito indicare “void”. Nell’esempio seguente la funzione “mostra_messaggio” non restituisce nessun valore.
1 2 3 |
void mostra_messaggio(){ cout<<"Questo e’ un sotto-programma\n "; } |
Esempio completo
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 |
/* Programma che calcola il volume di una sfera nota la superficie vol = 4/3 PI r^3 sup = 4 PI r^2 --> r = rad_quadrata di (sup / 4 PI) */ #include <cstdlib> #include <iostream> #include <cmath> using namespace std; //VARIABILI GLOBALI //float r, s, v; //const float PI=3.14; void calcola_volume_v1(){ //VARIABILI LOCALI float r, s, v; const float PI=3.14; cout<<"Superficie della sfera: "; cin>>s; r=sqrt(s/(4*PI)); //y=sqrt(16) --> y=4 cout<<r<<endl; v=4*PI*pow(r, 3)/3; //pow(4, 2) cout<<"Volume sfera: "<<v<<endl; } void calcola_volume_v2(float s){ //VARIABILI LOCALI float r, v; const float PI=3.14; r=sqrt(s/(4*PI)); //y=sqrt(16) --> y=4 v=4*PI*pow(r, 3)/3; //pow(4, 2) cout<<"Volume sfera: "<<v<<endl; } float calcola_volume_v3(float s){ //VARIABILI LOCALI float r, v; const float PI=3.14; r=sqrt(s/(4*PI)); //y=sqrt(16) --> y=4 v=4*PI*pow(r, 3)/3; //pow(4, 2) return(v); } int main(int argc, char *argv[]) { //METODO 1 calcola_volume_v1(); //METODO 2 float s; cout<<"Superficie della sfera: "; cin>>s; calcola_volume_v2(s); //METODO 3 //float s; float v; cout<<"Superficie della sfera: "; cin>>s; v=calcola_volume_v3(s); cout<<"Volume sfera: "<<v<<endl; system("pause"); return 0; } |