Definizione di metodi in Java
|
|
|
- Enzo Vitali
- 9 anni fa
- Просмотров:
Транскрипт
1 Definizione di metodi in Java Un metodo in Java definisce un operazione ad alto livello (sottoprogramma) che consente di manipolare dati e oggetti. Durante la computazione effettuata da un programma, un operazione può essere applicata piú volte e su argomenti di volta in volta diversi. In tal caso è una buona tecnica di programmazione organizzare la computazione in maniera modulare individuando quelle operazioni (o funzionalità) che possono essere definite in modo piú astratto per operare su argomenti diversi. Come abbiamo già detto, ogni metodo è contenuto in una classe. Una classe può contenere la definizione di vari metodi. I metodi contengono dichiarazioni ed istruzioni. Un metodo può richiedere degli argomenti su cui operare e restituisce un valore che è il risultato della sua computazione oppure non restituisce alcun valore, ma semplicemente il metodo effettua delle modifiche sullo stato della macchina (per esempio, il metodo può modificare una qualche caratteristica di un oggetto o stampare una sequenza di caratteri). Supponiamo di voler scrivere un semplice programma Java che calcola il prodotto di due numeri naturali tramite l algoritmo basato sulla somma. Poiché durante una computazione può essere necessario applicare piú volte l operazione del prodotto, è opportuno definire un metodo che, dati due numeri naturali, calcola e restituisce il risultato del loro prodotto. Il metodo main (necessario per avere un programma Java eseguibile) può limitarsi a prendere in input i numeri da sommare (forniti dall utente), invocare l applicazione del metodo che implementa l operazione di prodotto e, per esempio, provvedere a visualizzare il risultato. Tipicamente conviene organizzare le varie classi con i loro metodi nel modo seguente. Si definisce una classe per file (con la corrispondenza tra i nomi già ricordata). I vari metodi sono definiti in una o piú classi, ed il main viene messo in una classe separata di test (o utilizzo). Ad esempio, possiamo definire la classe Mult nel file Mult.java contenente un metodo mult definito come segue: 1 public class Mult { public static int mult (int x, int y) { int z = 0; z = z+x; e poi definiamo una classe MultTest nel file MultTest.java contenente il seguente metodo main: public class MultTest { int x = Integer.parseInt(args[0]); int y = Integer.parseInt(args[1]); System.out.println(Mult.mult(x,y)); Il metodo mult definisce l operazione di moltiplicazione di due numeri naturali tramite la somma, mentre il metodo main prende in input due valori, chiama il metodo mult su tali 1 Nel seguito anche le classi verranno definite pubbliche tramite la parola riservata public. Nota che in un file può essere definita al piú una classe pubblica ed il suo nome deve corrispondere al nome del file.
2 valori e poi ne stampa il risultato. In questo esempio, il metodo mult è quindi chiamato (o invocato) dal metodo main, che agisce da metodo chiamante. Vediamo come sono stati definiti questi due metodi. L intestazione del metodo mult è public static int mult (int x, int y) da cui deriviamo le seguenti informazioni: - il metodo è definito pubblico (tipicamente i nostri metodi saranno definiti pubblici, in modo che possano essere invocati da qualsiasi punto del programma); - il metodo è statico (si dice anche che è un metodo di classe) in quanto dipende solo dalla classe in cui è definito e non dall oggetto su cui verrà applicato; - il metodo restituisce un valore di tipo intero (denotato dal tipo int dopo la parola riservata static); - mult è il nome (un identificatore) del metodo; - il metodo si aspetta due valori in ingresso, entrambi di tipo intero, denotati da (int x, int y). Questi sono i parametri formali del metodo, specificati mediante una lista di coppie della forma Tipo ParametroIde, dove Tipo è il tipo (pre-definito in Java o definito dall utente) del parametro corrispondente, il cui nome è l identificatore denotato da ParametroIde. Occorre ricordare che un metodo può non avere parametri, ma le parentesi vanno sempre scritte (sia in fase in definizione che in fase di chiamata del metodo). Il corpo della definizione del metodo è una sequenza di dichiarazioni locali al metodo (la variabile intera z) ed istruzioni che codificano in Java l algoritmo della moltiplicazione di due numeri naturali tramite la somma. Il codice del metodo termina con l istruzione la cui sintassi è data dalla parola riservata return seguita da un espressione il cui tipo è compatibile con quello del risultato del metodo (definito nell intestazione). Data un espressione E, la semantica dell istruzione return E consiste nel valutare E, ottenendo il suo valore v E, e nel restituire il controllo dell esecuzione al metodo chiamante passandogli il valore v E come risultato della chiamata del metodo. Infatti, nel metodo main, dopo aver opportunamente convertito i due valori in input ed averli memorizzati nelle variabili x ed y, si ha la chiamata del metodo mult come segue: Mult.mult(x,y) Il metodo mult è definito static, quindi la sua invocazione si effettua premettendo il nome della classe in cui è definito (seguito da un punto) al nome del metodo. Questa chiamata è (sintatticamente) un espressione di tipo int (il tipo del valore restituito da mult) ottenuto applicando il metodo mult della classe Mult sugli argomenti, detti parametri attuali, dati dalle espressioni x ed y (che sono, in particolare, degli identificatori di variabili). La modalità di passaggio dei parametri in Java è il passaggio per valore (in inglese callby-value). Ciò significa che vengono valutati i parametri attuali (nel nostro caso le variabili x ed y locali al main) ed i valori ottenuti vengono associati ai parametri formali 2, rispettando l ordine in cui tali parametri sono stati definiti. Quindi, si può compilare il programma tramite javac Mult.java javac MultTest.java o semplicemente (se i due file sono nella stessa cartella) tramite javac MultTest.java 2 Nell esempio anche i parametri formali del metodo mult sono denotati tramite x ed y, ma non vanno confusi con le variabili locali del main.
3 ovvero compilando solo il file in cui si trova il main (il compilatore provvede a compilare anche gli altri eventuali file da cui dipende il file con il main e genera anche i file.class degli altri). Quindi vengono generati i file Mult.class e MultTest.class e si può eseguire il programma mandando in esecuzione il file.class in cui si trova il main. Ad esempio: java MultTest Si ha che le variabili x ed y locali al main sono inizializzate con i valori interi 4 e 8 rispettivamente. Al momento della chiamata, tali valori sono passati al metodo mult ed associati ai parametri formali x ed y di mult. Il codice del metodo mult viene eseguito tenendo conto di tali legami. Il risultato calcolato e restituito dalla chiamata Mult.mult(x,y) viene infine stampato sul video tramite l esecuzione del metodo println. Possiamo definire altri metodi per la computazione di funzioni matematiche, mettendoli tutti nella stessa classe. 3 Definiamo, ad esempio, l operazione di esponenziazione tramite la moltiplicazione. public class Arith { public static int mult (int x, int y) { int z = 0; z = z+x; public static int exp (int x, int y) { int z = 1; z = mult(x,z); Poiché il metodo exp invoca un metodo definito nella sua stessa classe, è possibile evitare di specificare la classe nella chiamata del metodo mult. public class ArithTest { int x = Integer.parseInt(args[0]); int y = Integer.parseInt(args[1]); System.out.println(Arith.exp(x,y)); javac ArithTest.java java ArithTest Tutte queste funzioni sono pre-definite in Java e contenute nella classe Math.
4 Esercizi 1. Scrivere un metodo in Java che, dati in ingresso due numeri m, n ln tali che m < n, stampa tutti i numeri pari compresi tra m ed n, ovvero tutti i numeri x tali che x è pari e m x n. public static void stampapari (int m, int n) { int x; if (m%2 == 0) x = m; else x = m+1; while (x <= n) { System.out.println(x); x = x+2; Supponendo che il metodo stampapari sia definito nella classe StampaPari, un semplice programma di prova è il seguente: public class StampaPariTest { int m = Integer.parseInt(args[0]); int n = Integer.parseInt(args[1]); StampaPari.stampaPari(m,n); Nota che il tipo del risultato del metodo stampapari è void, quindi la chiamata del metodo StampaPari.stampaPari(m,n); è un istruzione. 2. Scrivere un metodo che calcola il fattoriale di un numero naturale n. Si ricorda la definizione del fattoriale: 0! = 1 ed n! = n (n 1) per n 1. Se al metodo viene passato un numero intero negativo, il metodo restituisce -1. public static int fattoriale (int n) { if (n<0) return -1; int f = 1; for (int i=1; i<=n; i++) f = f*i; return f; 3. Scrivere un metodo che calcola l n-esimo numero di Fibonacci. Si ricorda la definizione dei numeri di Fibonacci: fib(0) = 1, fib(1) = 1, fib(n) = fib(n 1)+fib(n 2) per n 2. Se al metodo viene passato un numero intero negativo, il metodo restituisce -1. public static int fibonacci (int n) { if (n<0) return -1; int fib, x, temp; fib = 1; x = 0;
5 for (int i=1; i<=n; i++) { temp = x+fib; x = fib; fib = temp; return fib; 4. Scrivere un metodo che, dato un intero n, stampa i primi n numeri di Fibonacci (incluso l n-esimo numero). 5. Scrivere un metodo che, dato un intero n, stampa i numeri di Fibonacci minori di n. 6. Scrivere un semplice programma di prova in cui vengono utilizzati i due metodi definiti ai punti precedenti.
Funzioni, Stack e Visibilità delle Variabili in C
Funzioni, Stack e Visibilità delle Variabili in C Programmazione I e Laboratorio Corso di Laurea in Informatica A.A. 2016/2017 Calendario delle lezioni Lez. 1 Lez. 2 Lez. 3 Lez. 4 Lez. 5 Lez. 6 Lez. 7
7 - Programmazione procedurale: Dichiarazione e chiamata di metodi ausiliari
7 - Programmazione procedurale: Dichiarazione e chiamata di metodi ausiliari Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa
Linguaggio C: le funzioni. Introduzione e sintassi
ISIS "Guido Tassinari" di Pozzuoli Indirizzo Informatico - Articolazione Informatica Informatica Prof. A.S. 2012/2013 Linguaggio C: le funzioni. Introduzione e sintassi 21/10/2012 Introduzione Spesso alcuni
Linguaggio C: le funzioni. Introduzione e sintassi
Dipartimento di Elettronica ed Informazione Politecnico di Milano Informatica e CAD (c.i.) - ICA Prof. Pierluigi Plebani A.A. 2008/2009 Linguaggio C: le funzioni. Introduzione e sintassi La presente dispensa
Variabili. Unità 2. Domenico Daniele Bloisi. Corso di Programmazione e Metodi Numerici Ingegneria Aerospaziale BAER
Corso di Programmazione e Metodi Numerici Ingegneria Aerospaziale BAER Domenico Daniele Bloisi Docenti Metodi Numerici prof. Vittoria Bruni [email protected] Programmazione prof. Domenico
Unità F1. Obiettivi. Il linguaggio C. Il linguaggio C++ Linguaggio C. Pseudolinguaggio. Primi programmi
Obiettivi Unità F1 Primi programmi Conoscere il significato di dichiarazione e definizione di variabili Conoscere i tipi di dato numerici Essere in grado di realizzare semplici algoritmi in pseudolinguaggio
Laboratorio di Programmazione Lezione 2. Cristian Del Fabbro
Laboratorio di Programmazione Lezione 2 Cristian Del Fabbro Prossima lezione GIOVEDÌ 29 OTTOBRE 14:00 Input da tastiera package input; import java.io.*; public class Input { public static void main(string[]
Programmazione Orientata agli Oggetti in Linguaggio Java
Programmazione Orientata agli Oggetti in Linguaggio Java Classi e Oggetti: Metafora Parte a versione 2.2 Questo lavoro è concesso in uso secondo i termini di una licenza Creative Commons (vedi ultima pagina)
Programmazione Orientata agli Oggetti. Emilio Di Giacomo e Walter Didimo
Programmazione Orientata agli Oggetti Emilio Di Giacomo e Walter Didimo Una metafora dal mondo reale la fabbrica di giocattoli progettisti Un semplice giocattolo Impara i suoni Dall idea al progetto Toy
Compitino di Laboratorio di Informatica CdL in Matematica 13/11/2007 Teoria Compito A
Matematica 13/11/2007 Teoria Compito A Domanda 1 Descrivere, eventualmente utilizzando uno schema, gli elementi funzionali di una CPU. Domanda 2 Java è un linguaggio compilato o interpretato? Motivare
Primi passi col linguaggio C
Andrea Marin Università Ca Foscari Venezia Laurea in Informatica Corso di Programmazione part-time a.a. 2011/2012 Come introdurre un linguaggio di programmazione? Obiettivi: Introduciamo una macchina astratta
Laboratorio di programmazione
Laboratorio di programmazione Lezione VIII Tatiana Zolo [email protected] 1 PROGRAMMAZIONE A OGGETTI Quando si programma a oggetti si scompone il problema in sottogruppi di parti collegate che tengono
6 - Blocchi e cicli. Programmazione e analisi di dati Modulo A: Programmazione in Java. Paolo Milazzo
6 - Blocchi e cicli Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://pages.di.unipi.it/milazzo milazzo di.unipi.it
FUNZIONI RICORSIVE PROGRAMMAZIONE RICORSIVA: Esempi di problemi ricorsivi:
FUNZIONI RICORSIVE Una funzione matematica è definita ricorsivamente quando nella sua definizione compare un riferimento (chiamata) a se stessa. Esempio: Esempi di problemi ricorsivi: 1) Somma dei primi
Programmazione. Cognome... Nome... Matricola... Prova scritta del 22 settembre 2014. Negli esercizi proposti si utilizzano le seguenti classi:
Cognome................................ Nome................................... Matricola............................... Programmazione Prova scritta del 22 settembre 2014 TEMPO DISPONIBILE: 2 ore Negli
IL PRIMO PROGRAMMA IN C
IL PRIMO PROGRAMMA IN C LO SCOPO Si vuole scrivere un programma in linguaggio C che chieda all utente di introdurre da tastiera due numeri interi e visualizzi il valore della loro somma sul video SOLUZIONE
Programmazione ad oggetti
Programmazione ad oggetti OOP La programmazione orientata agli oggetti (Object Oriented Programming) ha l obiettivo di formalizzare gli oggetti del mondo reale e di costruire con questi un mondo virtuale.
Esercizi Programmazione I
Esercizi Programmazione I 9 Novembre 201 Esercizio 1 Valutare e dare il tipo delle seguenti espressioni condizionali. 1 char a= a, b= b ; // a ha v a l o r e decimale 97 2 i n t i= 1, j= 2 ; 3 double x=
Modulo 2: Strutture fondamentali della programmazione Java
Modulo 2: Strutture fondamentali della programmazione Java Argomenti Trattati: Un semplice programma Java: Presentazione di un primo Esempio; Introduzione alla struttura; Compilazione ed esecuzione. Argomenti
ESECUZIONE DI PROGRAMMI C SU MACCHINE REALI. Docente: Giorgio Giacinto AA 2008/2009. formalizzazione degli algoritmi in linguaggio C
Università degli Studi di Cagliari Corso di Laurea Specialistica in Ingegneria per l Ambiente ed il Territorio Corso di Laurea Specialistica in Ingegneria Civile - Strutture FONDAMENTI DI INFORMATICA 2
Linguaggi di alto livello, compilatori e interpreti
Linguaggi di alto livello, compilatori e interpreti Percorso di Preparazione agli Studi di Ingegneria Università degli Studi di Brescia Docente: Massimiliano Giacomin Il punto della situazione STATO DATI
14 - Metodi e Costruttori
14 - Metodi e Costruttori Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://www.di.unipi.it/ milazzo milazzo di.unipi.it
Elementi lessicali. Lezione 4. La parole chiave. Elementi lessicali. Elementi lessicali e espressioni logiche. Linguaggi di Programmazione I
Lezione 4 Elementi lessicali e espressioni logiche Matricole 2-3 Elementi lessicali il linguaggio C ha un suo vocabolario di base i cui elementi sono detti token esistono 6 tipi di token: parole chiave
Le basi del linguaggio Java
Corso di Laurea Ingegneria Civile Fondamenti di Informatica Dispensa 10 Le basi del linguaggio Java Aprile 2010 Le basi del linguaggio Java 1 Prerequisiti Nozioni generali sulla sintassi e semantica del
Linguaggio C: introduzione
Dipartimento di Elettronica ed Informazione Politecnico di Milano Informatica e CAD (c.i.) - ICA Prof. Pierluigi Plebani A.A. 2008/2009 Linguaggio C: introduzione La presente dispensa e da utilizzarsi
Università degli Studi di Cassino Corso di Fondamenti di Informatica Tipi strutturati: Stringhe. Anno Accademico 2010/2011 Francesco Tortorella
Corso di Informatica Tipi strutturati: Stringhe Anno Accademico 2010/2011 Francesco Tortorella Stringhe di caratteri La stringa è il tipo strutturato con cui vengono rappresentati gruppi di caratteri quali
Esercizio 2 (punti 7) Dato il seguente programma C: #include <stdio.h> int swap(int * nome, int length);
Fondamenti di Informatica L-A (A.A. 004/005) - Ingegneria Informatica Prof.ssa Mello & Prof. Bellavista I Prova Intermedia del 11/11/004 - durata h - COMPITO B Esercizio 1 (punti 1) Una associazione di
Programmazione in Java (I modulo)
Programmazione in Java (I modulo) Lezione 4 Variabili di tipo primitivo. Dichiarazione di costanti Conversioni di tipo: operatore cast Altri operatori di assegnamento Operazioni aritmetiche e di confronto
Algoritmi di Ricerca. Esempi di programmi Java
Fondamenti di Informatica Algoritmi di Ricerca Esempi di programmi Java Fondamenti di Informatica - D. Talia - UNICAL 1 Ricerca in una sequenza di elementi Data una sequenza di elementi, occorre verificare
Programmazione. Cognome... Nome... Matricola... Prova scritta del 11 luglio 2014
Cognome................................ Nome................................... Matricola............................... Programmazione Prova scritta del 11 luglio 2014 TEMPO DISPONIBILE: 2 ore Negli esercizi
Algoritmi e basi del C Struttura di un programma
Algoritmi e basi del C Struttura di un programma Marco D. Santambrogio [email protected] Ver. aggiornata al 17 Marzo 2015 Compitini Compitini di INFO: 24 Aprile 2015 4.15pm @ C.G.1 (Ed. 9) 21
RETI DI CALCOLATORI Linguaggio Java: Eccezioni
Università degli Studi di Modena e Reggio Emilia Facoltà di Ingegneria Reggio Emilia CORSO DI RETI DI CALCOLATORI Linguaggio Java: Eccezioni Prof. Franco Zambonelli Lucidi realizzati in collaborazione
1 Esercizi in pseudocodice
Questa dispensa propone esercizi sulla scrittura di algoritmi in un linguaggio semiformale, utile all acquisizione delle abilità essenziali per implementare algoritmi in qualsiasi linguaggio di programmazione.
Linguaggio C. strutture di controllo: strutture iterative. Università degli Studi di Brescia. Docente: Massimiliano Giacomin
Linguaggio C strutture di controllo: strutture iterative Università degli Studi di Brescia Docente: Massimiliano Giacomin Elementi di Informatica e Programmazione Università di Brescia 1 Strutture iterative
ERRATA CORRIGE. void SvuotaBuffer(void); void SvuotaBuffer(void) { if(getchar()!=10) {svuotabuffer();} }
ERRATA CORRIGE Pulizia del buffer di input: come fare? (1) Dopo aver richiamato getchar() per prelevare un carattere dal buffer di input, inseriamo una seconda chiamata a getchar(), senza assegnare il
Lezione 6. Visibilità degli identificatori e tempo di vita degli oggetti
Lezione 6 Visibilità degli identificatori e tempo di vita degli oggetti Programmazione I Paolo Valente - 2009/2010 Ripasso dichiarazioni oggetti Finora abbiamo scritto le dichiarazioni di variabili e costanti
Corso di Fondamenti di Informatica Linguaggi di Programmazione
Corso di Fondamenti di Informatica Linguaggi di Programmazione Anno Accademico Francesco Tortorella Linguaggi di programmazione Un calcolatore basato sul modello di von Neumann permette l esecuzione di
Esercizio 1: funzione con valore di ritorno di tipo puntatore
Esercitazione Fondamenti di Informatica B Corso di Laurea in Ingegneria Meccanica 7 Esercitazione: 14 dicembre 2005 Esercizi su ricorsione, manipolazione stringhe, strutture dinamiche Problema: Esercizio
18 - Classi parzialmente definite: Classi Astratte e Interfacce
18 - Classi parzialmente definite: Classi Astratte e Interfacce Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://www.di.unipi.it/
TIPI PRIMITIVI: LIMITI
TIPI PRIMITIVI: LIMITI I tipi primitivi sono i "mattoni elementari" del linguaggio In varie situazioni può però essere necessario trattare i tipi primitivi come oggetti quando una funzione pretende come
Esercitazione 5. Procedure e Funzioni Il comando condizionale: switch
Esercitazione 5 Procedure e Funzioni Il comando condizionale: switch Comando: switch-case switch (espressione) { /* espressione deve essere case costante1: istruzione1 di tipo int o char */ [break]; case
Introduzione a Java. Prof. Francesco Accarino IIS Altiero Spinelli Via Leopardi132 Sesto San Giovanni
Introduzione a Java IIS Altiero Spinelli Via Leopardi132 Sesto San Giovanni Linguaggi di programmazione Ogni programma viene scritto utilizzando un linguaggio specializzato, formale e comprensibile da
Stringhe e allocazione dinamica della memoria
Stringhe e allocazione dinamica della memoria Esercizio Scrivere un programma strings.c che legge da standard input una sequenza di parole separate da uno o più spazi, e stampa le parole lette, una per
perror: individuare l errore quando una system call restituisce -1
perror: individuare l errore quando una system call restituisce -1 Quando una system call (o una funzione di libreria) non va a buon fine, restituisce come valore -1 Come si fa a sapere più precisamente
Il linguaggio di programmazione Python
Università Roma Tre Dipartimento di Matematica e Fisica Percorso Abilitante Speciale Classe A048 Matematica Applicata Corso di Informatica Il linguaggio di programmazione Python Marco Liverani ([email protected])
Uso di metodi statici. Walter Didimo
Uso di metodi statici Walter Didimo Metodi di istanza Fino ad ora abbiamo imparato a creare oggetti e ad invocare metodi su tali oggetti i metodi venivano eseguiti dagli oggetti un metodo invocato su un
Studio delle successioni con il software
Studio delle successioni con il software Abbiamo visto due possibili definizioni per alcune successioni: diretta e per ricorrenza (o ricorsiva). Ricordiamo che la successione delle somme dei primi n numeri
Il linguaggio C. Notate che...
Il linguaggio C Notate che... 1 Il C è un linguaggio a blocchi int main (void) { blocco } 2 Il C è un linguaggio a blocchi (2) Non è possibile mischiare dichiarazioni e comandi! int main (void) { } Dichiarazione
Programmazione Java Struttura di una classe, Costruttore, Riferimento this
Programmazione Java Struttura di una classe, Costruttore, Riferimento this [email protected] http://www.di.univaq.it/romina.eramo/tlp Roadmap > Struttura di una classe > Costruttore > Riferimento
Laboratorio di programmazione
Laboratorio di programmazione Lezione II Tatiana Zolo [email protected] 1 IL PROGRAMMA C++ Istruzioni (espressioni terminate da ; ) istruzioni di dichiarazione (es. int x = 0;); istruzioni di assegnamento
STRINGHE IN JAVA In Java, le stringhe non sono pezzi di memo-ria con dentro dei caratteri, come in C: sono oggetti appartenenti alla classe
STRINGHE IN JAVA In Java, le stringhe non sono pezzi di memo-ria con dentro dei caratteri, come in C: sono oggetti appartenenti alla classe String Una stringa Java rappresenta uno specifico valore e come
La programmazione nel linguaggio C
3 La programmazione nel linguaggio C 3.0 La programmazione nel linguaggio C c Diego Calvanese Fondamenti di Informatica Corso di Laurea in Ingegneria Elettronica A.A. 2001/2002 3.0 0 Introduzione ai programmi
Le Funzioni e la Ricorsione
Aula V Dip. di Matematica G. Castelnuovo Univ. di Roma La Sapienza Le Funzioni e la Ricorsione Igor Melatti Slides disponibili (assieme ad altro materiale) in: http://www.dsi.uniroma1.it/ melatti/programmazione1.2007.2008.html
Introduzione alla programmazione. Walter Didimo
Introduzione alla programmazione Walter Didimo Programmi Un programma è una frase (anche molto lunga) che descrive delle azioni che devono essere svolte da un calcolatore La frase deve essere dettagliata
