Realizzazione di Phone Plan. Soluzione - SimpleTime. Realizzazione e testing! Soluzione - SimpleTime. Soluzione - SimpleTime
|
|
- Berta Meli
- 8 anni fa
- Visualizzazioni
Transcript
1 Università degli Studi di Bologna Facoltà di Ingegneria Fondamenti di Informatica T2 Modulo 2 Corso di Laurea in Ingegneria Informatica Anno accademico 2008/2009 Realizzazione di Phone Plan Fare riferimento alla progettazione vista in aula Partire implementando prima le classi con meno dipendenze che, di conseguenza, sono più semplici, nell ordine: SimpleTime, Band, Operator, PhonePlan. 2 Realizzazione e testing! Usare Eclipse come ambiente di sviluppo Verificare di volta in volta quanto fatto fino alla verifica completa del funzionamento del sistema Per ogni classe creata, verificarne il corretto funzionamento Non eliminare i metodi di test: possono sempre servire! Usare il DayOfWeekEnum di cui al laboratorio precedente! Naturalmente deve essere stato realizzato (!) e testato in modo adeguato (!!) Soluzione - SimpleTime public class SimpleTime private int hours; private int minutes; public static final SimpleTime MIN_VALUE = new SimpleTime(0, 0); public static final SimpleTime MAX_VALUE = new SimpleTime(23, 59); public SimpleTime(int hours, int minutes) this.hours = hours % 24; this.minutes = minutes % 60; SimpleTime modella un orario in modo semplice in termini di ore e minuti. Ore valide se comprese fra 0 a 23. Minuti validi se compresi fra 0 a Soluzione - SimpleTime public int gethours() return hours; public int getminutes() return minutes; public SimpleTime addminutes(int mins) int newhours; int newminutes; Metodi accessor. Restituisce un nuovo orario con minuti pari alla somma fra i minuti dell oggetto corrente ed i minuti passati come parametro. newminutes = this.minutes + mins; newhours = this.hours + (newminutes > 59? 1 : 0); newminutes %= 60; return new SimpleTime(newHours, newminutes); 5 Soluzione - SimpleTime Verifica se l orario corrente è valido controllando la consistenza del suo stato. return this.compareto(min_value) >= 0 && this.compareto(max_value) <= 0; public boolean equals(simpletime time) if (time == null) Verifica l uguaglianza fra due oggetti di tipo SimpleTime. return this.hours == time.hours && this.minutes == time.minutes; 6
2 Soluzione - SimpleTime public int compareto(simpletime time) if (this.hours > time.hours) return 1; else if (this.hours == time.hours) if (this.minutes > time.minutes) return 1; else if (this.minutes == time.minutes) return 0; else else Confronta due oggetti di tipo SimpleTime. 7 import java.util.gregoriancalendar; Modella un giorno public class DayOfWeekEnum della settimana. public static final DayOfWeekEnum SUNDAY = new DayOfWeekEnum(GregorianCalendar.SUNDAY); public static final DayOfWeekEnum MONDAY = new DayOfWeekEnum(GregorianCalendar.MONDAY); public static final DayOfWeekEnum TUESDAY = new DayOfWeekEnum(GregorianCalendar.TUESDAY); public static final DayOfWeekEnum WEDNESDAY = new DayOfWeekEnum(GregorianCalendar.WEDNESDAY); public static final DayOfWeekEnum THURSDAY = new DayOfWeekEnum(GregorianCalendar.THURSDAY); 8 public static final DayOfWeekEnum FRIDAY = new DayOfWeekEnum(GregorianCalendar.FRIDAY); public static final DayOfWeekEnum SATURDAY = new DayOfWeekEnum(GregorianCalendar.SATURDAY); public int value; public DayOfWeekEnum(int gregoriacalendarday) this.value = gregoriancalendarday; Valore intero associato al giorno della settimana. 9 public boolean iscontainedin(dayofweekenum[] days) for (DayOfWeekEnum day : days) if (day == this) return true; public int togregoriancalendardayofweek() return value; Controlla se il giorno corrente è contenuto nell insieme di giorni passato come parametro. 10 public static DayOfWeekEnum[] values() return new DayOfWeekEnum[] SUNDAY, MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY; public static DayOfWeekEnum fromgregoriancalendardayofweek(int gregoriancalendarday) for (DayOfWeekEnum day : DayOfWeekEnum.values()) if (day.value == gregoriancalendarday) return day; return null; 11 import java.util.gregoriancalendar; public class Band private DayOfWeekEnum[] combinedays; private SimpleTime starttime; private SimpleTime endtime; private double costperinterval; public Band(SimpleTime starttime, SimpleTime endtime, DayOfWeekEnum[] days, double costperinterval) this.starttime = starttime; this.endtime = endtime; this.combineddays = days; this.costperinterval = costperinterval; Sfruttiamo le classi per la gestione delle date e dei calendari. Ora fine e inizio validità come SimpleTime e non come Date. Oggetto Band caratterizzato da: ora inizio / fine e giorni della settimana in cui la fascia oraria è valida, e costo dell intervallo. 12
3 public SimpleTime getstarttime() return starttime; public SimpleTime getendtime() return endtime; public DayOfWeekEnum[] getcombineddays() return combineddays; public double getcostperinterval() return costperinterval; Metodi accessor. 13 public boolean isinband(date startcall) GregorianCalendar calendar = new GregorianCalendar(); calendar.settime(startcall); Oggetto Verifica calendar se la fascia per estrarre è il giorno, applicabile l ora, e per i minuti una data/ora dalla data /ora passata come parametro. int day = calendar.get(gregoriancalendar.day_of_week); int hour = calendar.get(gregoriancalendar.hour_of_day); int minute = calendar.get(gregoriancalendar.minute); SimpleTime startcalltime = new SimpleTime(hour, minute); return DayOfWeekEnum.fromGregorianCalendarDayOfWeek(day). iscontainedin(combineddays) && starttime.compareto(startcalltime) <= 0 && endtime.compareto(startcalltime) >= 0; 14 Verifica se la fascia corrente è valida controllando la consistenza del suo stato. if (combineddays!= null && combineddays.length > 0 && starttime!= null && endtime!= null ) for (DayOfWeekEnum day : combineddays) if (day == null ) return starttime.compareto(endtime) < 0; 15 public static void sortbystarttime(band[] bands) for (int i = 0; i < bands.length; i++) for (int j = i + 1; j < bands.length; j++) if (bands[i].starttime.compareto(bands[j].starttime) > 0) Band temp = bands[i]; bands[i] = bands[j]; Ordina l array di fasce orarie bands[j] = temp; passate come parametro in ordine crescente per ora di inizio validità. 16 public class Operator private String name; private Band[] bands; public Operator(String name, Band[] bands) this.name = name; this.bands = bands; Un operatore telefonico è caratterizzato da un nome e da un insieme di fasce applicabili. 17 public String getname() return name; public Band[] getbands() return bands; Metodi accessor. public double getcostperinterval(date callstart) for (Band b : bands) if (b.isinband(callstart)) return b.getcostperinterval(); Fornisce il costo per una certa data / ora. 18
4 for (Band band : bands) if (!band.isvalid()) Verifica se l operatore corrente è valido controllando la consistenza del suo stato. In particolare, controlla che le bande siano tutte valide e for (DayOfWeekEnum day : DayOfWeekEnum.values()) if (!validateday(day))... che le bande coprino tutte le ore di tutti i giorni della settimana. return true; 19 private boolean validateday(dayofweekenum day) Seleziona le bande relative ad un if (day!= null) particolare giorno della settimana e... Band[] bandsinday = selectbandinday(day); Band.sortByStartTime(bandsInDay); sfruttando l ordinamento fra bande, controlla che queste coprano tutte le ore del giorno. for (int i = 0; i < bandsinday.length - 1; i++) SimpleTime firstbandendtime = bandsinday[i].getendtime(); SimpleTime secondbandstarttime = bandsinday[i + 1]. getstarttime(); if (!firstbandendtime.addminutes(1). equals(secondbandstarttime)) 20 else return bandsinday.length > 0 && bandsinday[0].getstarttime(). equals(simpletime.min_value) && bandsinday[bandsinday.length - 1]. getendtime().equals(simpletime.max_value); Se l insieme di bande coprono tutte le ore del giorno, il metodo ritorna true, altrimenti... il metodo ritorna false. 21 private Band[] selectbandinday(dayofweekenum day) int count = 0; Fornisce l insieme di bande relative ad un particolare giorno della settimana. for (Band band : bands) if (day.iscontainedin(band.getcombineddays())) count++; Band[] result = new Band[count]; int j = 0; for (int i = 0; i < bands.length; i++) if (day.iscontainedin(bands[i].getcombineddays())) result[j++] = bands[i]; return result; 22 public class Plan private String name; private int interval; private double startcallcost; private Operator[] operators; Un piano telefonico è caratterizzato dal nome del piano, dall intervallo standard, costo dello scatto alla risposta, e insieme degli operatori. public Plan(String name, int interval, int startcallcost, Operator[] operators) this.name = name; this.interval = interval; this.startcallcost = startcallcost; this.operators = operators; 23 public String getname() return name; public int getinterval() return interval; public double getstartcallcost() return startcallcost; Metodi accessor. 24
5 public double getcallcost(date callstart, Date callend, String destoperator, String destnumber) Operator selected = getoperatorbyname(destoperator); if (selected == null) double costperinterval = selected.getcostperinterval(callstart); if (costperinterval == -1) Fornisce il costo di una chiamata date le sue caratteristiche. long difference = callend.gettime() - callstart.gettime(); int intervalcount = (int)(difference / interval); 25 return startcallcost + intervalcount * costperinterval; public double getcallcost(phonecall call) return getcallcost(call.getcallstart(), call.getcallend(), call.getdestoperator(), call.getdestnumber()); Fornisce il costo di una chiamata dato un oggetto di tipo PhoneCall. for (Operator operator : operators) if (!operator.isvalid()) return true; Verifica se il piano telefonico corrente è valido controllando la validità degli operatori telefonici. 26 private Operator getoperatorbyname(string operatorname) Operator selected = null; for (Operator o : operators) if (o.getname().equals(operatorname)) selected = o; break; return selected; Fornisce l oggetto Operatore corrispondente al nome passato come parametro. 27 Soluzione - PhoneCall import java.text.dateformat; public class PhoneCall private Date callstart; private Date callend; private String destoperator; private String destnumber; Una chiamata telefonica è caratterizzata dalla data / ora di inizio e fine, dall operatore di destinazione, e dal numero di destinazione. public PhoneCall(Date callstart, Date callend, String destoperator, String destnumber) this.callstart = callstart; this.callend = callend; this.destoperator = destoperator; this.destnumber = destnumber; 28 Soluzione - PhoneCall public Date getcallstart() return callstart; public Date getcallend() return callend; public String getdestoperator() return destoperator; public String getdestnumber() return destnumber; Metodi accessor. 29 Soluzione - PhoneCall public String tostring() DateFormat shortformatter = DateFormat.getDateTimeInstance(DateFormat.SHORT, DateFormat.FULL); return shortformatter.format(callstart) + " -- " + shortformatter.format(callend) + " --> " + destnumber + (" + destoperator + )"; Rappresentazione a stringa di una chiamata telefonica. 30
6 import java.text.numberformat; import java.util.gregoriancalendar; import java.util.locale; public class PhonePlanMain Classe per testare l applicazione. 31 public static void main(string[] args) Come prima cosa imposta la cultura locale, cioè quella Locale.setDefault(Locale.ITALY); italiana. Plan plan = createplan(); PhoneCall[] calls = gettestphonecalls(); NumberFormat formatter = NumberFormat.getCurrencyInstance(); Crea un nuovo piano for (PhoneCall call : calls) telefonico e un insieme di chiamate telefoniche di System.out.print(call); test. System.out.print(" --- "); System.out.println(formatter.format( Stampa ciascuna chiamata ed il costo della chiamata con il piano plan. plan.getcallcost(call) / 100)); 32 public static Plan createplan() DayOfWeekEnum[] workweek = new DayOfWeekEnum[] DayOfWeekEnum.MONDAY, DayOfWeekEnum.TUESDAY, DayOfWeekEnum.WEDNESDAY, DayOfWeekEnum.THURSDAY, DayOfWeekEnum.FRIDAY; DayOfWeekEnum[] weekend = new DayOfWeekEnum[] DayOfWeekEnum.SATURDAY, DayOfWeekEnum.SUNDAY; Crea i giorni della settimana suddivisi in due insiemi: workweek e weekend. 33 Band[] timbands = new Band[] Crea le fasce telefoniche relative ai giorni della settimana new Band(new SimpleTime(0,0), new SimpleTime(23,59), weekend, 0.10), new Band(new SimpleTime(0,0), new SimpleTime(7,59), workweek, 0.10), new Band(new SimpleTime(8,0), new SimpleTime(17,59), workweek, 0.20) ; Crea l operatore TIM con le fasce appena create Operator tim = new Operator("TIM", timbands); 34 Band[] vodafonebands = new Band[] Crea un nuovo insieme di fasce telefoniche relative ai giorni della settimana new Band(new SimpleTime(0,0), new SimpleTime(23,59), weekend, 0.15), Crea e restituisce un insieme di chiamate telefoniche di test. public static PhoneCall[] gettestphonecalls() GregorianCalendar cal = new GregorianCalendar(); new Band(new SimpleTime(0,0), new SimpleTime(7,59), Date callstart, callend; Crea una prima workweek, 0.15), chiamata verso cal.set(2009, 02, 10, 15, 21, 21); l operatore new Band(new SimpleTime(8,0), new SimpleTime(17,59), callstart = cal.gettime(); TIM, effettuata workweek, 0.30) cal.set(gregoriancalendar.hour_of_day, 15); il 10/02/2009, ; Crea l operatore Vodafone con le fasce appena create cal.set(gregoriancalendar.minute, 25); dalle 15:21:21 alle 15:25:23. Operator vodafone = new Operator("Vodafone", vodafonebands); cal.set(gregoriancalendar.second, 23); return new Plan("SuperConveniente", 1000, 10, new callend = cal.gettime(); Operator[] tim,vodafone); PhoneCall call1 = new PhoneCall(callStart, callend, Crea un nuovo piano "TIM", SuperConveniente con gli " "); operatori TIM e Vodafone
7 Crea una seconda chiamata verso l operatore cal.set(2009, 02, 10, 16, 35, 55); Vodafone. callstart = cal.gettime(); cal.set(gregoriancalendar.hour_of_day, 16); cal.set(gregoriancalendar.minute, 41); cal.set(gregoriancalendar.second, 23); callend = cal.gettime(); PhoneCall call2 = new PhoneCall(callStart, callend, Vodafone, " "); Crea una terza chiamata verso l operatore TIM. cal.set(2009, 02, 10, 17, 21, 21); callstart = cal.gettime(); cal.set(gregoriancalendar.hour_of_day, 18); cal.set(gregoriancalendar.minute, 25); cal.set(gregoriancalendar.second, 23); callend = cal.gettime(); PhoneCall call3 = new PhoneCall(callStart, callend, TIM, " ); return new PhoneCall[] call1, call2, call3; 37 38
Realizzazione di Phone Plan
Università degli Studi di Bologna Facoltà di Ingegneria Fondamenti di Informatica T2 Modulo 2 Corso di Laurea in Ingegneria Informatica Anno accademico 2008/2009 Realizzazione di Phone Plan Fare riferimento
DettagliFondamenti di Informatica T2 Modulo 2. Corso di Laurea in Ingegneria Informatica Anno accademico 2008/2009. Phone Plan
Università degli Studi di Bologna Facoltà di Ingegneria Fondamenti di Informatica T2 Modulo 2 Corso di Laurea in Ingegneria Informatica Anno accademico 2008/2009 Phone Plan Si desidera modellare il funzionamento
DettagliCorso di Laurea in Ingegneria Gestionale Esame di Informatica a.a. 2012-13 14 giugno 2013
Cognome Nome Matricola Postazione PC Corso di Laurea in Ingegneria Gestionale Esame di Informatica a.a. 2012-13 14 giugno 2013 Testo Il database di una banca è costituito da due vettori paralleli. Il primo
DettagliFondamenti di Informatica T2 Modulo 2. Corso di Laurea in Ingegneria Informatica Anno accademico 2014/2015. Ancora Phone Plan
Università degli Studi di Bologna Scuola di Ingegneria e Architettura Fondamenti di Informatica T2 Modulo 2 Corso di Laurea in Ingegneria Informatica Anno accademico 2014/2015 Ancora Phone Plan Quanto
DettagliFondamenti di Informatica T2 Modulo 2. Corso di Laurea in Ingegneria Informatica Anno accademico 2008/2009. Veicoli
Università degli Studi di Bologna Facoltà di Ingegneria Fondamenti di Informatica T2 Modulo 2 Corso di Laurea in Ingegneria Informatica Anno accademico 2008/2009 Veicoli Si desidera realizzare una o più
DettagliVeicoli. Veicoli. Veicoli. Veicoli. Veicoli. Fondamenti di Informatica T2 Modulo 2. Università di Bologna A.A. 2008/2009
Università degli Studi di Bologna Facoltà di Ingegneria Fondamenti di Informatica T2 Modulo 2 Corso di Laurea in Ingegneria Informatica Anno accademico 2008/2009 Si desidera realizzare una o più classi
DettagliCorso di Laurea in Ingegneria Gestionale Esame di Informatica - a.a. 2012-13 25 luglio 2013
Cognome Nome Matricola Postazione PC Corso di Laurea in Ingegneria Gestionale Esame di Informatica - a.a. 2012-13 25 luglio 2013 Testo Il database di una banca è costituito da due vettori paralleli. Il
DettagliStudente (Cognome Nome): Corso di Informatica Corso di Laurea in Ingegneria Gestionale a.a. 2007-08 Primo scritto 11 Gennaio 2008
Studente (Cognome Nome): Matricola: Corso di Informatica Corso di Laurea in Ingegneria Gestionale a.a. 2007-08 Primo scritto 11 Gennaio 2008 Si noti che le soluzioni ai quesiti saranno considerate valide
DettagliAlgoritmi 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
DettagliEsempi di esercizi d esame
Esempi di esercizi d esame Fondamenti di Informatica L-B 1 Cellulare Testo esercizio: 1.Specifiche Si richiede di realizzare una classe che implementa il funzionamento di un telefono cellulare Tale classe
DettagliCorso di Laurea in Ingegneria Gestionale Esame di Informatica a.a. 2010-11 13 settembre 2011
Cognome Nome Matricola Postazione PC Corso di Laurea in Ingegneria Gestionale Esame di Informatica a.a. 2010-11 13 settembre 2011 Testo Il database di un videonoleggio è costituito da due vettori paralleli.
DettagliEsercizi sulla definizione di classi (Fondamenti di Informatica 1 Walter Didimo) Soluzioni
Esercizi sulla definizione di classi (Fondamenti di Informatica 1 Walter Didimo) Soluzioni Esercizio 1 Nella classe definita di seguito indicare quali sono le variabili di istanza, quali sono le variabili
DettagliTipi primitivi. Ad esempio, il codice seguente dichiara una variabile di tipo intero, le assegna il valore 5 e stampa a schermo il suo contenuto:
Tipi primitivi Il linguaggio Java offre alcuni tipi di dato primitivi Una variabile di tipo primitivo può essere utilizzata direttamente. Non è un riferimento e non ha senso tentare di istanziarla mediante
DettagliUso di JUnit. Fondamenti di informatica Oggetti e Java. JUnit. Luca Cabibbo. ottobre 2012
Fondamenti di informatica Oggetti e Java ottobre 2012 1 JUnit JUnit è uno strumento per assistere il programmatore Java nel testing JUnit consente di scrivere test di oggetti e classi Java i test sono
DettagliLinguaggi Corso M-Z - Laurea in Ingegneria Informatica A.A. 2007-2008. Esercitazione. Programmazione Object Oriented in Java
Linguaggi Corso M-Z - Laurea in Ingegneria Informatica A.A. 2007-2008 Alessandro Longheu http://www.diit.unict.it/users/alongheu alessandro.longheu@diit.unict.it Programmazione Object Oriented in Java
DettagliEsercitazione 6. Tutor: Ing. Diego Rughetti. Anno Accademico 2007/2008
Dipartimento di Informatica e Sistemistica Antonio Ruberti Sapienza Università di Roma Esercitazione 6 Corso di Tecniche di programmazione Laurea in Ingegneria Informatica (Canale di Ingegneria delle Reti
DettagliSAPIENZA Università di Roma, Facoltà di Ingegneria
SAPIENZA Università di Roma, Facoltà di Ingegneria Corso di PROGETTAZIONE DEL SOFTWARE Laurea in Ingegneria Informatica Prof. E.Casalicchio A.A. 2008/09 QUARTA PARTE: Soluzioni Esercizi 13-23 Soluzione
Dettagli12 - Introduzione alla Programmazione Orientata agli Oggetti (Object Oriented Programming OOP)
12 - Introduzione alla Programmazione Orientata agli Oggetti (Object Oriented Programming OOP) Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica,
DettagliCorso di Laurea Ingegneria Informatica Fondamenti di Informatica
Corso di Laurea Ingegneria Informatica Fondamenti di Informatica Dispensa E01 Esempi di programmi A. Miola Ottobre 2011 1 Contenuti Vediamo in questa lezione alcuni primi semplici esempi di applicazioni
DettagliINFORMATICA GRAFICA - FONDAMENTI DI INFORMATICA Ing. Civile - Edile/Architettura Dott. Penzo SOLUZIONE PROVA SCRITTA DEL 16/09/2002.
INFORMATICA GRAFICA - FONDAMENTI DI INFORMATICA Ing. Civile - Edile/Architettura Dott. Penzo SOLUZIONE PROVA SCRITTA DEL 16/09/2002 Esercizio 4) import fiji.io.simplereader; class Programma{ public static
DettagliCorso di Laurea Ingegneria Informatica Fondamenti di Informatica 2
Corso di Laurea Ingegneria Informatica Fondamenti di Informatica 2 Dispensa 12 ADT: Lista, Pila, Coda A. Miola Marzo 2008 http://www.dia.uniroma3.it/~java/fondinf2/ ADT: Lista, Pila, Coda 1 Contenuti!Tipo
DettagliLAVORI ESTIVI DI INFORMATICA PER LA CLASSE IV Sez. Ainf (Prof. Tessore Luca)
Ministero dell Istruzione, dell Università e della Ricerca Istituto Tecnico Industriale Statale Enrico Mattei Via Martiri di Cefalonia 46-20097 San Donato Milanese Tel. 0255691411 - Fax 025276676 itisando@tin.it
DettagliCOMPITO DI LABORATORIO DI PROGRAMMAZIONE 2001-2002 17 Luglio 2002. Soluzione degli Esercizi
COMPITO DI LABORATORIO DI PROGRAMMAZIONE 2001-2002 17 Luglio 2002 degli Esercizi ESERCIZIO 1. Si consideri il seguente frammento di codice in linguaggio Java: int i=0, j=0; int[][] a=b; boolean trovato=false;
DettagliStudente (Cognome Nome): Corso di Informatica Corso di Laurea in Ingegneria Gestionale a.a. 2006-07 Secondo Compitino 21 Dicembre 2006
Studente (Cognome Nome): Matricola: Corso di Informatica Corso di Laurea in Ingegneria Gestionale a.a. 2006-07 Secondo Compitino 21 Dicembre 2006 Si noti che le soluzioni ai quesiti saranno considerate
Dettagli13 - Gestione della Memoria nella Programmazione Orientata agli Oggetti
13 - Gestione della Memoria nella Programmazione Orientata agli Oggetti Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://www.di.unipi.it/
DettagliRealizzazione di una classe con un associazione
Realizzazione di una classe con un associazione Nel realizzare una classe che è coinvolta in un associazione, ci dobbiamo chiedere se la classe ha responsabilità sull associazione. Diciamo che una classe
DettagliSAPIENZA Università di Roma Facoltà di Ingegneria dell Informazione, Informatica e Statistica
SAPIENZA Università di Roma Facoltà di Ingegneria dell Informazione, Informatica e Statistica Esercitazioni di PROGETTAZIONE DEL SOFTWARE (Corsi di Laurea in Ingegneria Informatica ed Automatica ed Ingegneria
DettagliEsercizi della lezione 5 di Java
Esercizi della lezione 5 di Java Esercizio 5 Create il tipo di dato Counter dell Esercizio 1 come sottoclasse del tipo di dato SimpleCounter. Esercizio 1 Create un tipo di dato Counter che abbia: un valore
DettagliEsercizio 6 Realizzare una classe astratta per le Figure piane e due sottoclassi, la sottoclasse Quadrato e la sottoclasse Rettangolo.
Esercizio 6 Realizzare una classe astratta per le Figure piane e due sottoclassi, la sottoclasse Quadrato e la sottoclasse Rettangolo. public abstract class FiguraPiana2{ private double base; public FiguraPiana2(double
DettagliProgrammazione 1 A.A. 2015/2016
Cognome e Nome Matricola (se disponibile) Programmazione 1 A.A. 2015/2016 Parziale del 4 Novembre 2015 Compito n 1 Esercizio 1 (4 punti) Convertire da base 16 a base 2 il numero FA1 Convertire da base
DettagliLe variabili. Olga Scotti
Le variabili Olga Scotti Cos è una variabile Le variabili, in un linguaggio di programmazione, sono dei contenitori. Possono essere riempiti con un valore che poi può essere riletto oppure sostituito.
DettagliCorso di Laurea Ingegneria Informatica Fondamenti di Informatica 2
Corso di Laurea Ingegneria Informatica Fondamenti di Informatica 2 Dispensa E08 Soluzione Esercizi F. Gasparetti, C. Limongelli Marzo 2008 http://www.dia.uniroma3.it/~java/fondinf1/ Soluzione Esercizi
DettagliSoluzioni degli esercizi di riepilogo (Fondamenti di Informatica 1 Walter Didimo)
Soluzioni degli esercizi di riepilogo (Fondamenti di Informatica 1 Walter Didimo) Soluzioni delle prove al calcolatore Esercizio 7 (esame del 08/01/2009) class TabellaDiNumeri{ private double[][] tabella;
DettagliLABORATORIO DI PROGRAMMAZIONE 1 CORSO DI LAUREA IN MATEMATICA UNIVERSITÀ DEGLI STUDI DI MILANO 2014 2015 15.V.2015. Indice
LABORATORIO DI PROGRAMMAZIONE 1 CORSO DI LAUREA IN MATEMATICA UNIVERSITÀ DEGLI STUDI DI MILANO 2014 2015 15.V.2015 VINCENZO MARRA Indice Parte 1. Input/Output standard dalla console 2 Esercizio 1 2 Eco
DettagliLa selezione binaria
Andrea Marin Università Ca Foscari Venezia Laurea in Informatica Corso di Programmazione part-time a.a. 2011/2012 Introduzione L esecuzione di tutte le istruzioni in sequenza può non è sufficiente per
DettagliSupermarket Progetto di Programmazione Febbraio 2010
Supermarket Progetto di Programmazione Febbraio 2010 1 Supermercato Dovete realizzare un insieme di classi e interfacce che riguardano la gestione di un supermercato. nella Sezione 2 verranno descritte
DettagliCorso di Laurea Ingegneria Informatica Fondamenti di Informatica 2
Corso di Laurea Ingegneria Informatica Fondamenti di Informatica 2 Dispensa 10 Strutture collegate - 2 A. Miola Febbraio 2008 http://www.dia.uniroma3.it/~java/fondinf2/ Strutture collegate - 2 1 Contenuti!Strutture
DettagliReflection in Java. Linguaggi Corso M-Z - Laurea in Ingegneria Informatica A.A. 2009-2010
Linguaggi Corso M-Z - Laurea in Ingegneria Informatica A.A. 2009-2010 Alessandro Longheu http://www.diit.unict.it/users/alongheu alessandro.longheu@diit.unict.it Reflection in Java 1 Reflection Riflessione
DettagliLa gestione dell input/output da tastiera La gestione dell input/output da file La gestione delle eccezioni
La gestione dell input/output da tastiera La gestione dell input/output da file La gestione delle eccezioni Autore: Prof. Agostino Sorbara ITIS "M. M. Milano" Autore: Prof. Agostino Sorbara ITIS "M. M.
DettagliProssime lezioni. Dai TDA agli oggetti. Riassunto. Riassunto TDA. Oggi. Stefano Mizzaro 1
Prossime lezioni Dai TDA agli oggetti Stefano Mizzaro Dipartimento di matematica e informatica Università di Udine http://www.dimi.uniud.it/mizzaro mizzaro@dimi.uniud.it Programmazione, lezione 18 19 gennaio
DettagliSpecifica i tipi di oggetti a creare, utilizzando un istanza prototipo, e crea nuove istanze tramite la copia di questo prototipo.
Prototype 28 4. Prototype (GoF pag. 117) 4.1. Descrizione 4.2. Esempio Specifica i tipi di oggetti a creare, utilizzando un istanza prototipo, e crea nuove istanze tramite la copia di questo prototipo.
DettagliLaboratorio di Informatica Lezione 2
Laboratorio di Informatica Lezione 2 Cristian Consonni 30 settembre 2015 Cristian Consonni Laboratorio di Informatica, Lezione 2 1 / 42 Outline 1 Commenti e Stampa a schermo 2 Strutture di controllo 3
DettagliAppello di Informatica B
Politecnico di Milano Facoltà di Ingegneria Industriale 19 febbraio 2004 Appello di Informatica B Prof. Angelo Morzenti - Prof. Vincenzo Martena Cognome e nome: Matricola: Tipo di prova: recupero I prova
DettagliAlgebra di Boole: Concetti di base. Fondamenti di Informatica - D. Talia - UNICAL 1. Fondamenti di Informatica
Fondamenti di Informatica Algebra di Boole: Concetti di base Fondamenti di Informatica - D. Talia - UNICAL 1 Algebra di Boole E un algebra basata su tre operazioni logiche OR AND NOT Ed operandi che possono
DettagliParcheggio.rtf 1/8 6 gennaio 2009. Prova di programmazione: parcheggio a pagamento
Parcheggio.rtf 1/8 6 gennaio 2009 Prova di programmazione: parcheggio a pagamento Si sviluppi il codice per la gestione di un parcheggio a pagamento mediante la classe Parcheggio, che ospita le auto rappresentate
DettagliGESTIONE DEI PROCESSI
Sistemi Operativi GESTIONE DEI PROCESSI Processi Concetto di Processo Scheduling di Processi Operazioni su Processi Processi Cooperanti Concetto di Thread Modelli Multithread I thread in Java Concetto
DettagliSOMMARIO Coda (queue): QUEUE. QUEUE : specifica QUEUE
SOMMARIO Coda (queue): Specifica: interfaccia. Implementazione: Strutture indicizzate (array): Array di dimensione variabile. Array circolari. Strutture collegate (nodi). Prestazioni. Strutture Software
Dettagliesercizi Esercizi / problemi
Sistemi informativi applicati (reti di calcolatori): esercizi 1 Esercizi / problemi 1. Creare un applicazione che calcoli la media aritmetica dei seguenti valori interi: 35, 117, 23 e ne visualizzi il
DettagliFunzioni in C. Violetta Lonati
Università degli studi di Milano Dipartimento di Scienze dell Informazione Laboratorio di algoritmi e strutture dati Corso di laurea in Informatica Funzioni - in breve: Funzioni Definizione di funzioni
DettagliProgrammazione a oggetti e JAVA. Prof. B.Buttarazzi A.A. 2011/2012
Programmazione a oggetti e JAVA Prof. B.Buttarazzi A.A. 2011/2012 Sommario Variabili statiche Ereditarietà multipla Le interfacce Binding Esercizi Esercizio ContoCorrente Creare una classe ContoCorrente
DettagliEsercizio: la classe CashRegister
Esercizio: la classe CashRegister Si veda anche il libro di testo: Consigli pratici 3.1 Sezione 4.2 Sezione 8.2 Esercizi 8.1 e 8.2 1 Problema Si chiede di realizzare una classe CashRegister che simuli
DettagliInternazionalizzazione: il supporto alle culture locali
Università degli Studi di Bologna Facoltà di Ingegneria Fondamenti di Informatica T2 Modulo 2 Corso di Laurea in Ingegneria Informatica Anno accademico 2008/2009 Internazionalizzazione: il supporto alle
DettagliEsercitazioni di Progettazione del Software. Esercitazione (Prova al calcolatore del 17 settembre 2010)
Sapienza - Università di Roma Facoltà di Ingegneria dell Informazione, Informatica e Statistica Corso di Laurea in Ingegneria Informatica ed Automatica, Ingegneria dei Sistemi Informatici Esercitazioni
DettagliIngegneria del Software
Ingegneria del Software Java Relazioni Associazioni 1 Associazione Uno a Zero-Uno Un esempio Un autovettura ha al più un proprietario 0..1 Dato il verso di navigazione specificato è necessario avere una
Dettagli3 - Variabili. Programmazione e analisi di dati Modulo A: Programmazione in Java. Paolo Milazzo
3 - Variabili 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 Corso di
DettagliGESTIONE INFORMATICA DEI DATI AZIENDALI
GESTIONE INFORMATICA DEI DATI AZIENDALI Alberto ZANONI Centro Vito Volterra Università Tor Vergata Via Columbia 2, 00133 Roma, Italy zanoni@volterra.uniroma2.it Rudimenti di programmazione Programming
DettagliOttava Esercitazione. introduzione ai thread java mutua esclusione
Ottava Esercitazione introduzione ai thread java mutua esclusione Agenda Esempio 1 Concorrenza in Java: creazione ed attivazione di thread concorrenti. Esercizio 2 da svolgere Concorrenza in Java: sincronizzazione
DettagliCorso di Informatica Corso di Laurea in Ingegneria Gestionale a.a. 2005-06 Secondo Compitino 17 Dicembre 2005
Studente (Cognome Nome): Matricola: Corso di Informatica Corso di Laurea in Ingegneria Gestionale a.a. 2005-06 Secondo Compitino 17 Dicembre 2005 Si noti che le soluzioni ai quesiti saranno considerate
DettagliDefinizione di classi con array di oggetti
Definizione di classi con array di oggetti 1. (Esame scritto del 18/9/2002, Esercizio 6.) La banca dati di un agenzia assicurativa per auto è caratterizzata da un insieme di polizze di assicurazioni per
DettagliEsercitazioni aggiuntive Martedì 14-17 -- Laboratorio L-12
Laboratorio LP2 Esercitazioni aggiuntive Martedì 14-17 -- Laboratorio L-12 ventre@dia.unisa.it Esercizio P14.8 Scrivete un programma Find che cerchi in tutti i file specificati sulla riga di comando una
Dettaglidall argomento argomento della malloc()
Allocazione dinamica Quando? Tutte le volte in cui i dati possono crescere in modo non prevedibile staticamente a tempo di sviluppo Un array con dimensione i fissata a compile-time non è sufficiente È
DettagliJava: Compilatore e Interprete
Java: Compilatore e Interprete Java Virtual Machine Il bytecode non è Linguaggio Macchina. Per diventarlo, deve subire un ulteriore trasformazione che viene operata dall interprete Java in modalità JIT
DettagliInternazionalizzazione: il supporto alle culture locali. Internazionalizzazione: il supporto alle culture locali. Formattazione di numeri (1/3)
Università degli Studi di Bologna Facoltà di Ingegneria Fondamenti di Informatica T2 Modulo 2 Corso di Laurea in Ingegneria Informatica Anno accademico 2008/2009 Internazionalizzazione: il supporto alle
DettagliSiti web centrati sui dati Architettura MVC-2: i JavaBeans
Siti web centrati sui dati Architettura MVC-2: i JavaBeans 1 ALBERTO BELUSSI ANNO ACCADEMICO 2009/2010 Limiti dell approccio SEVLET UNICA La servlet svolge tre tipi di funzioni distinte: Interazione con
Dettagli// inizializzazione della biblioteca con utenti, libri e prestiti // non richiesta Biblioteca.inizializza();
// Fondamenti di Informatica/Informatica Grafica // Soluzione del compito del 21/03/2003 // per semplicità si è deciso di riportare in un unico file il testo // delle soluzioni degli esercizi 1, 2 e 3.
DettagliEsercitazione n 4. Obiettivi
Esercitazione n 4 Obiettivi Progettare e implementare per intero un componente software in Java Linguaggio Java: Classi astratte Utilizzo di costruttori e metodi di superclasse Polimorfismo Esempio guida:
DettagliProgrammazione ad Oggetti Modulo A (Esame del 11/9/2015)
Programmazione ad Oggetti Modulo A (Esame del 11/9/2015) Esercizio 1 Considerate la seguente gerarchia di classi: class A { public void print(string s) { System.out.println(s); public void m1() { print("a.m1");
DettagliEsempio: il conto bancario
Ereditarietà Prof. Francesco Scarcello D.E.I.S., Università della Calabria Corso di Informatica 2 Esempio: il conto bancario public class BankAccount { public BankAccount() { balance = 0; public BankAccount(double
DettagliARRAY BIDIMENSIONALI float [][] mx = new float[3][4]; (float []) [] mx = new float[3][4];
ARRAY BIDIMENSIONALI Si possono definire array di qualunque tipo di dato, quindi anche di altre array float [][] mx = new float[3][4]; ovvero.. (float []) [] mx = new float[3][4]; La loro motivazione (storica)
DettagliCaso d Uso: AcquistoAbbonamentoStudentiSettimanaleGiornaliero Breve descrizione. Procedura per la registrazione al servizio CicloPi.
Corso di Ingegneria del software Seconda verifica 27 maggio 2015 F. Gadducci, L. Semini - Dipartimento di Informatica, Università di Pisa, a.a. 2014/15 La prova si svolge a libri chiusi (non è permessa
DettagliConcetto di Funzione e Procedura METODI in Java
Fondamenti di Informatica Concetto di Funzione e Procedura METODI in Java Fondamenti di Informatica - D. Talia - UNICAL 1 Metodi e Sottoprogrammi Mentre in Java tramite le classi e gli oggetti è possibile
DettagliFondamenti di Informatica C Esercitazioni di Laboratorio / 3 http://polaris.ing.unimo.it/fic/laboratorio.html. Outline
Fondamenti di Informatica C Esercitazioni di Laboratorio / 3 http://polaris.ing.unimo.it/fic/laboratorio.html Ing. Francesco De Mola demola.francesco@unimore.it DII, Modena Via Vignolese (lab. Dottorandi
DettagliArchitettura MVC-2: i JavaBeans
Siti web centrati sui dati Architettura MVC-2: i JavaBeans Alberto Belussi anno accademico 2008/2009 Limiti dell approccio SEVLET UNICA La servlet svolge tre tipi di funzioni distinte: Interazione con
DettagliUn esercizio d esame. Flavio De Paoli
Un esercizio d esame e note sulla gestione dei dati Flavio De Paoli Il testo (Appello 22 ottobre 2001) Una stazione di servizio dispone di n distributori di benzina. I clienti si presentano a uno dei distributori
DettagliUniversità di Torino Facoltà di Scienze MFN Corso di Studi in Informatica. Programmazione I - corso B a.a. 2009-10. prof.
Università di Torino Facoltà di Scienze MFN Corso di Studi in Informatica Programmazione I - corso B a.a. 009-10 prof. Viviana Bono Blocco 9 Metodi statici: passaggio parametri, variabili locali, record
Dettagli10 - Programmare con gli Array
10 - Programmare con gli Array 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
DettagliMain System Monitor Keyboard
Composite 57 8. Composite (Gof pag. 163) 8.1. Descrizione Consente la costruzione di gerarchie di oggetti composti. Gli oggetti composti possono essere conformati da oggetti singoli, oppure da altri oggetti
DettagliCorso di Informatica
Corso di Informatica Modulo T3 1-Sottoprogrammi 1 Prerequisiti Tecnica top-down Programmazione elementare 2 1 Introduzione Lo scopo di questa Unità è utilizzare la metodologia di progettazione top-down
DettagliOggetti Lezione 3. aspetti generali e definizione di classi I
Programmazione a Oggetti Lezione 3 Il linguaggio Java: aspetti generali e definizione di classi I Sommario Storia e Motivazioni Definizione di Classi Campi e Metodi Istanziazione di oggetti Introduzione
DettagliCorso di Laurea in Ingegneria Gestionale Esame di Informatica a.a. 2009-10 I scritto Febbraio 11 Febbraio 2011
Cognome Matricola Nome Postazione PC Corso di Laurea in Ingegneria Gestionale Esame di Informatica a.a. 2009-10 I scritto Febbraio 11 Febbraio 2011 Quesito La Biblioteca è costituita da due array: il primo
DettagliPolitecnico di Milano. Ingegneria del Software a.a. 2006/07. Appello del 14 settembre 2007 Cognome Nome Matricola
Politecnico di Milano Ingegneria del Software a.a. 2006/07 Appello del 14 settembre 2007 Cognome Nome Matricola Sezione (segnarne una) Baresi, Ghezzi, Morzenti, SanPietro Istruzioni 1. La mancata indicazione
DettagliFondamenti di Informatica 1. Prof. B.Buttarazzi A.A. 2010/2011
Fondamenti di Informatica 1 Prof. B.Buttarazzi A.A. 2010/2011 Sommario Paradigma OO Incapsulamento Polimorfismo e Overloading Ereditarietà e Overriding Esercizi svolti Esercizi proposti Paradigma OO Le
DettagliProgrammazione ad Oggetti: JAVA. Esercitazione
Programmazione ad Oggetti: JAVA Esercitazione Docente Ing. Mariateresa Celardo mariateresa.celardo@uniroma2.it Scrivere la classe Motorino che ha i seguenti attributi colore: una stringa indicante il colore
DettagliFondamenti di Informatica T2 Modulo 2. Corso di Laurea in Ingegneria Informatica Anno accademico 2008/2009. Enumerativi
Università degli Studi di Bologna Facoltà di Ingegneria Fondamenti di Informatica T2 Modulo 2 Corso di Laurea in Ingegneria Informatica Anno accademico 2008/2009 Enumerativi Finora abbiamo creato enumerativi
DettagliCorso di Laurea Ingegneria Informatica Fondamenti di Informatica 2
Corso di Laurea Ingegneria Informatica Fondamenti di Informatica 2 Dispensa 11 Tipi astratti di dato e loro rappresentazione A. Miola Marzo 28 http://www.dia.uniroma3.it/~java/fondinf2/ ADT e Rappresentazione
DettagliGli array. Gli array. Gli array. Classi di memorizzazione per array. Inizializzazione esplicita degli array. Array e puntatori
Gli array Array e puntatori Laboratorio di Informatica I un array è un insieme di elementi (valori) avente le seguenti caratteristiche: - un array è ordinato: agli elementi dell array è assegnato un ordine
DettagliSottoprogrammi: astrazione procedurale
Sottoprogrammi: astrazione procedurale Incapsulamento di un segmento di programma presente = false; j = 0; while ( (j
DettagliEsercizi classi e array
Esercizi classi e array Raffaella Brighi, a.a. 2006/07 Corso di Algoritmi e programmazione. A.A. 2006-07 CdL Operatore Informatico Giuridico. Progetto DataSet Realizzare una classe DataSet per la gestione
DettagliCorso di Fondamenti di Informatica Algoritmi su array / 2
Corso di Fondamenti di Informatica Algoritmi su array / Anno Accademico 00/009 Francesco Tortorella Algoritmi su array Operazioni tipiche sugli array: inizializzazione lettura stampa ricerca del minimo
DettagliFondamenti di Informatica. Dichiarazione, creazione e gestione di array in Java
Fondamenti di Informatica Dichiarazione, creazione e gestione di array in Java Array in Java - creazione La creazione fa una inizializzazione implicita: num = new int[10]; con valore 0 per int e double,
DettagliIntroduzione alla programmazione in C
Introduzione alla programmazione in C Testi Consigliati: A. Kelley & I. Pohl C didattica e programmazione B.W. Kernighan & D. M. Ritchie Linguaggio C P. Tosoratti Introduzione all informatica Materiale
DettagliParola chiave extends
Il Linguaggio Java Ereditarietà Ereditarietà L'ereditarietà permette di creare nuove classi sulla base di classi esistenti In particolare, permette di riusare il codice (metodi e campi); aggiungere nuovi
DettagliCorso di Laurea Ingegneria Informatica Fondamenti di Informatica
Corso di Laurea Ingegneria Informatica Fondamenti di Informatica Dispensa E04 Esempi di algoritmi e programmi C. Limongelli - A. Miola Novembre 2011 1 Contenuti q Somma di una sequenza di numeri interi
DettagliChat. Si ha un server in ascolto sulla porta 4444. Quando un client richiede la connessione, il server risponde con: Connessione accettata.
Chat Si ha un server in ascolto sulla porta 4444 Quando un client richiede la connessione, il server risponde con: Connessione accettata. Nome: Il client deve rispondere con lo user name A questo punto
DettagliIntroduzione a Classi e Oggetti
Introduzione a Classi e Oggetti Oggetto: concetto astratto Entità di un programma dotata di tre proprietà caratteristiche stato informazioni conservate nell oggetto condizionano il comportamento dell oggetto
DettagliInizializzazione, Assegnamento e Distruzione di Classi
Inizializzazione, Assegnamento e Distruzione di Classi Lezione 9 Operazioni Automatiche In ogni programma C++ oggetti classe vengono gestiti automaticamente dal compilatore Inizializzati al momento della
DettagliEsercizi Capitolo 6 - Alberi binari di ricerca
Esercizi Capitolo 6 - Alberi binari di ricerca Alberto Montresor 23 settembre 200 Alcuni degli esercizi che seguono sono associati alle rispettive soluzioni. Se il vostro lettore PDF lo consente, è possibile
DettagliProgrammazione in Java Parte I: Fondamenti
Programmazione in Java Parte I: Fondamenti Lezione 1 Dott. Marco Faella Riferimenti Testi consigliati: Progettazione del software e design pattern in Java di C.S. Horstmann Apogeo Gli esempi di codice
DettagliAlgoritmi su array / 2
Corso di Informatica Algoritmi su array / Anno Accademico / Francesco Tortorella Algoritmi su array Operazioni tipiche sugli array: inizializzazione lettura stampa ricerca del minimo e del massimo ricerca
Dettagli