Module: (Python) Subroutine: procedure e funzioni - 1


Problem

1/11

Subroutine: Introduzione

Theory Click to read/hide

Sottoroutine

Una subroutine è una parte separata del programma che ha un nome e risolve il proprio compito separato. La subroutine si trova all'inizio del programma principale e può essere lanciata (chiamata) dal programma principale specificandone il nome.

L'utilizzo delle subroutine consente di evitare la duplicazione del codice, se è necessario scrivere lo stesso codice in punti diversi del programma. 
Le librerie che vengono importate in un programma (per esempio, la libreria matematica math) consistono in subroutine che sono già state compilate da qualcuno. I programmatori non hanno bisogno di pensare a quali algoritmi implementano, ma semplicemente li applicano, pensando solo a cosa stanno facendo esattamente. Questo è un grande risparmio di tempo. Non è necessario scrivere un algoritmo che è già stato scritto da qualcun altro.

Ogni subroutine dovrebbe eseguire solo un compito,  puoi semplicemente calcolare qualcosa, o generare alcuni dati o fare qualcos'altro. 

Esistono due tipi di subroutine: procedure e funzioni.

Le sottoprocedure eseguono alcune azioni, come la visualizzazione di un risultato sullo schermo in una certa forma (un semplice esempio, l'istruzione print() è una sottoprocedura standard che stampa i dati sullo schermo).

Le subroutine delle funzioni restituiscono un risultato (numero, stringa di caratteri, ecc.) che possiamo utilizzare nel programma principale.

Proviamo a scrivere una semplice procedura:
Supponiamo di dover visualizzare sullo schermo la stringa "Errore". ogni volta che può verificarsi un errore nel codice per colpa dell'utente, ad esempio quando inserisce dati errati.
Questo può essere fatto scrivendo la dichiarazione print("Errore") E ora immagina che una riga del genere debba essere inserita in molti punti del programma. Certo, puoi semplicemente scriverlo ovunque. Ma questa soluzione ha due inconvenienti.
1) Questa stringa verrà memorizzata molte volte.
2) Se vogliamo modificare l'output in caso di errore, dovremo modificare questa riga in tutto il programma, il che è piuttosto scomodo

Per tali casi, sono necessarie procedure.
Un programma con una procedura potrebbe avere questo aspetto:
  def printError(): # descrizione della procedura print("Errore") ... printError() # avvia la procedura per l'esecuzione. # Basta specificare il nome della procedura che vogliamo eseguire ... stampaErrore()
Devi ricordare!
  1. La procedura inizia con la parola def (dall'inglese - define - definire). Dopo il nome della procedura, vengono scritte parentesi vuote e due punti . I parametri possono essere specificati all'interno delle parentesi (ne parleremo più avanti).
  2. Tutte le istruzioni eseguite in una procedura sono rientrate. 
  3. Per eseguire una procedura, nel programma principale devi chiamarla per nome e ricordarti di scrivere le parentesi!
  4. Puoi chiamare una procedura in un programma tutte le volte che vuoi.

Problem

Scrivete una procedura che visualizzi la frase "Errore. Divisione per zero! Assegnare il nome corretto alla procedura.