Diagramma delle classi UML
|
|
|
- Gianmarco Paoletti
- 6 anni fa
- Visualizzazioni
Transcript
1 Università di Roma La Sapienza, Facoltà di Ingegneria Corso di PROGETTAZIONE DEL SOFTWARE (Ing. Gestionale) Giuseppe De Giacomo e Monica Scannapieco, A.A SOLUZIONE ESAME DEL 11/07/2003 Roma, 9 marzo Diagramma delle classi UML 2
2 Diagramma e specifica degli use case //UML-usecase-diagram.txt _ _ / \ Verifiche / \ Scene produttore \ / InizioSpecificaUseCase VerificheScene metripellicola(s: Scena): reale pre: nessuna post: result e la somma dei metri di pellicola utilizzati complessivamente in tutti i ciak di tutti i setup della scena s dovesigira(s: Scena): stringa pre: nessuna post: result e la stringa che identifica la location se s e una scena in esterno o il teatro di posa se s e una scena in interno. FineSpecifica 3 Responsabilità sulle associazioni Dalla specifica dello use case e delle molteplicità minime nel diagramma delle classi emerge che: Scena ha responsabilità su relativo a Setup ha responsabilità su relativo a e su di ScenaInEsterno ha responsabilità su situata le altre classi non hanno responsabilità sulle associazioni. 4
3 Diagramma delle classi realizzativo 5 La classe Java TipoLinkRelativoA // File TipoLinkRelativoA.java public class TipoLinkRelativoA { //Rappr. componenti della tupla private final Scena lascena; private final Setup ilsetup; //Costruttore public TipoLinkRelativoA(Scena x, Setup y) { lascena = x; ilsetup = y; //Accesso alle componenti public Scena getscena() { return lascena; public Setup getsetup() { return ilsetup; //Overriding di funzioni speciali ereditate da Object //Nota TipoLinkRelativoA e un tipo non una classe: //va rdefinito equals per effettuare test di uguaglianza profonda public boolean equals(object o) { if (o!= null && getclass().equals(o.getclass())) { TipoLinkRelativoA b = (TipoLinkRelativoA)o; return b.lascena!= null && b.ilsetup!= null && b.lascena.equals(lascena) && b.ilsetup.equals(ilsetup); else return false; 6
4 La classe Java AssociazioneRelativoA // File AssociazioneRelativoA.java public class AssociazioneRelativoA { private AssociazioneRelativoA(TipoLinkRelativoA x) { link = x; private TipoLinkRelativoA link; public TipoLinkRelativoA getlink() { return link; public static void inserisci(tipolinkrelativoa y) { if (y.getscena()!= null && y.getsetup()!= null) { AssociazioneRelativoA k = new AssociazioneRelativoA(y); y.getscena().inseriscilinkrelativoa(k); y.getsetup().inseriscilinkrelativoa(k); public static void elimina(tipolinkrelativoa y) { if (y.getscena()!= null && y.getsetup()!= null) { AssociazioneRelativoA k = new AssociazioneRelativoA(y); y.getscena().eliminalinkrelativoa(k); y.getsetup().eliminalinkrelativoa(k); 7
5 L interfaccia Java SupportoAssociazioneRelativoA public interface SupportoAssociazioneRelativoA { void inseriscilinkrelativoa(associazionerelativoa a); void eliminalinkrelativoa(associazionerelativoa a); 8 // File Scena.java import java.util.*; La classe Java Scena abstract public class Scena implements SupportoAssociazioneRelativoA { //Rappr. attributi private final String id; private final String descrizione; //Rappr. associazione "relativo_a" private Set insieme_link; //Costruttore protected Scena(String i, String d) { id = i; descrizione = d; insieme_link = new InsiemeArrayOmogeneo(TipoLinkRelativoA.class); //Accesso agli attributi public String getid() { return id; public String getdescrizione() { return descrizione; //Accesso alla associazione "relativo_a" public boolean verificamoltminrelativoa() { return insieme_link.size() > 0; public Iterator getlinkrelativoa() { 9
6 if (verificamoltminrelativoa() == false) throw new RuntimeException( "Scena: partecipazione obbligatoria in relativo_a violata"); return insieme_link.iterator(); public void inseriscilinkrelativoa(associazionerelativoa a) { if (a!= null && a.getlink().getscena() == this) insieme_link.add(a.getlink()); else throw new RuntimeException("Inserimento impossibile!"); public void eliminalinkrelativoa(associazionerelativoa a) { if (a.getlink()!= null) insieme_link.remove(a.getlink()); else throw new RuntimeException("Eliminazione impossibile!"); //Overriding delle funzione speciali (cioe solo tostring) public String tostring() { return "Scena " + id + ", " + descrizione; // File Setup.java import java.util.*; La classe Java Setup public class Setup implements SupportoAssociazioneRelativoA { //Rappr. attributi private final String id; private final String parametri_ripresa; //Rappr. associazione "relativo_a" private TipoLinkRelativoA relativo_a; //Rappr. associazione "di" private Set insieme_ciak; //Costruttore public Setup(String i, String pr) { id = i; parametri_ripresa = pr; insieme_ciak = new InsiemeArrayOmogeneo(Ciak.class); //Accesso agli attributi public String getid() { return id; public String getparametriripresa() { return parametri_ripresa; //Accesso alla associazione "relativo_a" public boolean verificamoltminrelativoa() { return parametri_ripresa!= null; 10
7 public TipoLinkRelativoA getlinkrelativoa() { if ( verificamoltminrelativoa() == false) throw new RuntimeException( "Setup: partecipazione obbligatoria in relativo_a violata"); return relativo_a; public void inseriscilinkrelativoa(associazionerelativoa a) { if (a!= null && a.getlink().getsetup() == this && relativo_a == null) relativo_a = a.getlink(); else throw new RuntimeException("Inserimento impossibile!"); public void eliminalinkrelativoa(associazionerelativoa a) { if (a!= null && relativo_a.equals(a.getlink())) relativo_a = null; else throw new RuntimeException("Eliminazione impossibile!"); //Accesso alla associazione "di" public boolean verificamoltminciak() { return insieme_ciak.size() > 0; public Iterator getciak() { if (verificamoltminciak() == false) throw new RuntimeException( "Scena: partecipazione obbligatoria in relativo_a violata"); return insieme_ciak.iterator(); public void inserisciciak(ciak c) { if (c!= null) insieme_ciak.add(c); public void eliminaciak(ciak c) { if (c!= null) insieme_ciak.remove(c); //Overriding delle funzione speciali (cioe solo tostring) public String tostring() { return "Setup " + id + ", " + parametri_ripresa;
8 La classe Java Ciak // File Ciak.java public class Ciak { //Rappr. attributi private final int num; private final double metripellicola; private final String bobina; //Costruttore public Ciak(int n, double m, String b) { num = n; metripellicola = m; bobina = b; //Accesso agli attributi public double getnum() { return num; public double getmetripellicola() { return metripellicola; public String getidbobina() { return bobina; 11 La classe Java ScenaInInterno // File ScenaInInterno.java public class ScenaInInterno extends Scena { private final String idteatroposa; public ScenaInInterno(String i, String d, String t) { super(i,d); idteatroposa = t; public String getidteatroposa() { return idteatroposa; 12
9 // File ScenaInEsterno.java La classe Java ScenaInEsterno public class ScenaInEsterno extends Scena { private final boolean notturno; private Location loc; public ScenaInEsterno(String i, String d, boolean b) { super(i,d); notturno = b; public boolean getestnotturno() { return notturno; public boolean verificamoltminlocation() { return loc!= null; public Location getlocation() { if (verificamoltminlocation() == false) throw new RuntimeException( "ScenaInEsterno: partecipazione obbligatoria in situata violata"); return loc; public void setlocation(location l) { loc = l; 13 La classe Java Location // File Location.java public class Location { //Rappr. attributi private final String nome; private final String luogo; private final String descrizione; //Costruttore public Location(String n, String l, String d) { nome = n; luogo = l; descrizione = d; //Accesso agli attributi public String getnome() { return nome; public String getluogo() { return luogo; public String getdescrizione() { return descrizione; 14
10 Realizzazione in Java dello use case // File VerificheScene.java import java.util.*; public class VerificheScene { public static double metripellicola(scena s) { double ris = 0; Iterator it = s.getlinkrelativoa(); while(it.hasnext()) { TipoLinkRelativoA t = (TipoLinkRelativoA)it.next(); Iterator it2 = t.getsetup().getciak(); while(it2.hasnext()) { Ciak c = (Ciak)it2.next(); ris = ris + c.getmetripellicola(); return ris; /* public static String dovesigira(scena s) { if (ScenaInInterno.class.isInstance(s)) return ((ScenaInInterno)s).getIdTeatroPosa(); else return ((ScenaInEsterno)s).getLocation().getLuogo(); */ public static String dovesigira(scena s) { if (s instanceof ScenaInInterno) 15 return ((ScenaInInterno)s).getIdTeatroPosa(); else return ((ScenaInEsterno)s).getLocation().getLuogo();
11 InsiemeArray //Realizzazione dell interfaccia Set con un array invece che con una lista import java.util.*; import java.lang.reflect.array; public class InsiemeArray implements Set, Cloneable { // campi dati protected Object[] array; protected static final int diminit = 10; //dim. iniz. array protected int cardinalita; // costruttori public InsiemeArray() { array = new Object[dimInit]; cardinalita = 0; // funzioni proprie della classe // (realizzazione delle funzioni di Set) // basic operations public int size() { return cardinalita; public boolean isempty() { 16 return cardinalita == 0; public boolean contains(object e) { return appartiene(e); public boolean add(object e) { if (appartiene(e)) return false; else { if (cardinalita == array.length) {// raddoppia array Object[] aux = new Object[array.length*2]; for(int i = 0; i < array.length; i++) aux[i] = array[i]; array = aux; array[cardinalita] = e; cardinalita++; return true; public boolean remove(object e) { if (!appartiene(e)) return false; else { int k = 0; // trova l elemento while (!array[k].equals(e)) k++; for(int i = k; i < cardinalita-1; i++) // sposta di una poss array[i] = array[i+1]; // verso il basso gli // elementi dell array
12 cardinalita--; // rimpicciolisci l array se e il caso if (cardinalita > diminit && cardinalita < array.length/3) { Object[] aux = new Object[array.length/2]; for(int i = 0; i < cardinalita; i++) aux[i]=array[i]; array = aux; return true; public Iterator iterator() { return new IteratorInsiemeArray(this); // bulk operations public boolean containsall(collection c) { Iterator it = c.iterator(); while (it.hasnext()) { Object e = it.next(); if (!contains(e)) return false; return true; public boolean addall(collection c){ throw new UnsupportedOperationException("addlAll() non e supportata"); public boolean removeall(collection c) { throw new UnsupportedOperationException("removeAll() non e supportata"); public boolean retainall(collection c) { throw new UnsupportedOperationException("retainAll() non e supportata"); public void clear() { throw new UnsupportedOperationException("clear() non e supportata"); // array operations public Object[] toarray() { Object[] a = new Object[size()]; int i = 0; Iterator it = iterator(); while (it.hasnext()) { a[i] = it.next(); i++; return a; public Object[] toarray(object[] a) { if (a.length < size()) { //prendi il tipo degli elementi di a Class elemclass = a.getclass().getcomponenttype(); //costruisci un array il cui tipo degli elementi e quello in a a = (Object[])Array.newInstance(elemClass,size()); //riempi l array con gli elementi della collezione int i = 0;
13 Iterator it = iterator(); while (it.hasnext()) { a[i] = it.next(); i++; for (; i < a.length; i++) a[i] = null; return a; // funzioni speciali ereditate da Object public boolean equals(object o) { if (o!= null && getclass().equals(o.getclass())) { InsiemeArray ins = (InsiemeArray)o; if (cardinalita!= ins.cardinalita) return false; // ins non ha la cardinalita giusta else { // verifica che gli elementi nella lista siano gli stessi for(int i = 0; i < ins.cardinalita; i++) if (!appartiene(ins.array[i])) return false; return true; return false; public Object clone() { try { InsiemeArray ins = (InsiemeArray) super.clone(); ins.array = new Object[array.length]; for(int i = 0; i < cardinalita; i++) ins.array[i]=array[i]; return ins; catch(clonenotsupportedexception e) { throw new InternalError(e.toString()); public String tostring() { String s = "{ "; for(int i = 0; i < cardinalita; i++) s = s + array[i] + " "; s = s + ""; return s; // funzioni ausiliarie protected boolean appartiene(object e) { for(int i = 0; i < cardinalita; i++) if (array[i].equals(e)) return true; return false;
14 import java.util.*; IteratorInsiemeArray class IteratorInsiemeArray implements Iterator { // nota non e pubblica, cioe ne impediamo l uso diretto da parte // dei clienti (che quindi possono usare solo l interfaccia Iterator) private InsiemeArray insiemearray; private int indice; public IteratorInsiemeArray(InsiemeArray ia) { insiemearray = ia; indice = 0; // Realizzazione funzioni di Itarator public boolean hasnext() { return indice < insiemearray.cardinalita; public Object next() { Object e = insiemearray.array[indice]; indice++; return e; public void remove() { throw new UnsupportedOperationException("remove() non e supportata"); 17
SAPIENZA 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
Corso Linguaggi di programmazione II - Unina Esercitazione (prova intercorso)
1) Si considerino le classi Java: Corso Linguaggi di programmazione II - Unina Esercitazione (prova intercorso) class Card Card (String seed, int value) this.seed=seed; this.value=value; String seed; int
La fase di progetto e realizzazione. PROGETTAZIONE DEL SOFTWARE (Ing. Gestionale) Diagramma delle classi realizzativo
Università di Roma La Sapienza, Facoltà di Ingegneria Corso di PROGETTAZIONE DEL SOFTWARE (Ing. Gestionale) Prof. Giuseppe De Giacomo & Monica Scannapieco Anno Accademico 2003/04 LA FASE DI PROGETTO E
QUEUE : considerazioni. QUEUE : considerazioni. QUEUE : esempio. QUEUE : esempio
QUEUE : considerazioni QUEUE : considerazioni Si è realizzata una struttura dati complessa utilizzandone una primitiva, l array. Il pregio di tale implementazione è il basso costo computazionale, mentre
Algoritmi e Strutture Dati. Tipo di dato astratto e Strutture dati elementari
Algoritmi e Strutture Dati Tipo di dato astratto e Strutture dati elementari 1 Argomenti della lezione Tipi di dato astratto Strutture dati elementari Liste o Implementazione di liste in Java Stack Code
SAPIENZA 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: LA FASE DI REALIZZAZIONE La fase di
Realizzazione 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
Corso 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
INFORMATICA 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
La fase di realizzazione. La fase di realizzazione (cont.) Traduzione in Java del diagramma degli use case
Università degli Studi di Roma La Sapienza Corso di Laurea in Ingegneria dell Informazione Sede di Latina Corso di Laurea in Ingegneria dell Informazione Consorzio Nettuno La fase di realizzazione si occupa
Politecnico 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
Java. Linguaggi di Programmazione Linguaggi Speciali & Tecnologie dei Linguaggi di Programmazione: Scritto del 30 Giugno 2006
Linguaggi di Programmazione Linguaggi Speciali & Tecnologie dei Linguaggi di Programmazione: Scritto del 30 Giugno 2006 Java Nome e Cognome: Matricola: Corso di Laurea: Date le classi seguenti: class Point
Laboratorio di Programmazione II Corso di Laurea in Bioinformatica Dipartimento di Informatica - Università di Verona
Laboratorio di Programmazione II Corso di Laurea in Bioinformatica Dipartimento di Informatica - Università di Verona Tipi Tipo Astratto di Permette di specicare dati in modo astratto Astratto Indipendentemente
Programmazione 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");
// 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.
Programmazione ad oggetti
DAIS Univ. Ca' Foscari Venezia Programmazione ad oggetti Samuel Rota Bulò Classi astratte Le classi astratte sono un ibrido tra le classi concrete e le interfacce. Hanno le stesse caratteristiche di una
Programmazione 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
SAPIENZA 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
L ambizione dei design pattern (letteralmente schemi di programmazione) è quella di offrire soluzioni a problemi ricorrenti che facilitano lo
Design Pattern L ambizione dei design pattern (letteralmente schemi di programmazione) è quella di offrire soluzioni a problemi ricorrenti che facilitano lo sviluppo dei programmi, il loro mantenimento,
ARRAYLIST. Programmazione con Java ArrayList e Generics 2 08/06/2014. Daniela Micucci [email protected]
Programmazione con Java ArrayList e Generics Daniela Micucci [email protected] ARRAYLIST Programmazione con Java ArrayList e Generics 2 1 La classe ArrayList Fa parte delle librerie standard di
Synchronized (ancora)
Synchronized (ancora) Riscriviamo l esempio di prima. Usiamo una struttura modulare, con una classe Notificatore che ha opportuni metodi. La classe ha due campi privati, la lista buftext e un suo thread.
Esercitazione 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
Esercizi 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
Scope e visibilità per classi
Scope e visibilità per classi Packages Classi interne nelle loro diverse forme Interne / statiche / locali Utilizzo congiunto con interfacce Implementazione di iteratori Gestione di eventi Packages Package:
R. Focardi 2002 Laboratorio di Ingegneria del Software Slide 1. Applicazioni = programmi stand-alone
Il linguaggio Java Nato nel maggio 95 (James Gosling & al.) Orientato ad oggetti, basato sulle classi, concorrente Fortemente tipato: distinzione chiara tra errori statici ed errori dinamici Ad alto livello:
esercizi 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
Linguaggi 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 [email protected] Programmazione Object Oriented in Java
Reflection 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 [email protected] Reflection in Java 1 Reflection Riflessione
Studente (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
Parcheggio.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
COMPITO 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;
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)
Corso 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
Algoritmi e Strutture Dati & Laboratorio di Algoritmi e Programmazione
Algoritmi e Strutture Dati & Laboratorio di Algoritmi e Programmazione Appello dell 8 Febbraio 2005 Esercizio 1 (ASD) 1. Dire quale delle seguenti affermazioni è vera giustificando la risposta. (a) lg
Corso 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
Strutture dati "classiche"
Modulo di Roadmap 0. Primi passi con Java 1. Buone abitudini 2. Tipi di dati primitivi 3. Uso di classi 4. Leggere e scrivere 5. Definire metodi 6. Strutture di controllo 7. Array e Collection 8. Progetto
Progetto ingegneria del software: la torre di Hanoi
Progetto ingegneria del software: la torre di Hanoi Docente: Rosario Culmone Studente: Edmondo Barocci Matr. 078426 1 Indice 1. Analisi 3 1.1 Analisi del testo 3 1.2 Vocabolario dei termini 4 1.3 Use case
Programmazione Orientata agli Oggetti in Linguaggio Java
Programmazione Orientata agli Oggetti in Linguaggio Java Tecniche di Programmazione: C# versione 1.1 Questo lavoro è concesso in uso secondo i termini di una licenza Creative Commons (vedi ultima pagina)
Fondamenti 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
Corso 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
JAVA in ACTION. Jacopo Torrini. Dipartimento di Ingegneria dell'informazione Laboratorio di Tecnologie del Software. jacopo.torrini@jaewa.
JAVA in ACTION Jacopo Torrini Dipartimento di Ingegneria dell'informazione Laboratorio di Tecnologie del Software [email protected] Installazione Java Su Windows, dal sito Oracle installare l'ultima
Studente (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
Lezione 6 Collezioni. Il concetto astratto di collezione. Servizio minimo: IContainer. Stack (pila)
Lezione 6 Collezioni Il problema delle collezioni è molto vasto, ed è stato oggetto di studio fin dai primordi dell'informatica. Per esplorarlo senza perdersi è bene proporsi un metodo. Seguiremo il seguente:
Corso 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
! Programmazione strutturata ! TDA. ! Classi, incapsulamento, ! OO. ! Scambio messaggi, eredità, polimorfismo. ! OO in Java
Riassunto Rassegna API - 1 Stefano Mizzaro Dipartimento di matematica e informatica Università di Udine http://www.dimi.uniud.it/mizzaro/ [email protected] Programmazione, lezione 17 3 maggio 2015! Programmazione
Corso 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
/** * VETTORE DINAMICO elementi */ private Vector elementi; /** * METODO COSTRUTTORE */ public coda() { elementi=new Vector(); }
import java.util.*; class coda * Questa classe contiene tutti i metodi per la gestione della coda * @author D'Ambrosio Giovanni Classe 4D I.T.I.S. Grottaminarda * @version 26/02/2010 * VETTORE DINAMICO
ORM: Approccio DAO. Versione preliminare. Antonella Poggi. Dipartimento di informatica e Sistemistica Sapienza Università di Roma
ORM: Approccio DAO Versione preliminare Antonella Poggi Dipartimento di informatica e Sistemistica Sapienza Università di Roma Progetto di Applicazioni Software Anno accademico 2008-2009 Questi lucidi
Activation In sintesi: è inutile avere attivi degli oggetti se non vengono utilizzati
Activation In generale i Sistemi ad oggetti distribuiti sono progettati per lavorare con oggetti persistenti. Dato che questi sistemi saranno composti da migliaia (forse milioni) di tali oggetti, sarebbe
Programmazione Orientata agli Oggetti in Linguaggio Java
Programmazione Orientata agli Oggetti in Linguaggio Java Design Pattern: Storia Parte b versione 2.1 Questo lavoro è concesso in uso secondo i termini di una licenza Creative Commons (vedi ultima pagina)
12 - 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,
Esercizi 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
UML Diagrammi delle classi. UML Diagramma classi 1
UML Diagrammi delle classi UML Diagramma classi 1 Diagramma delle classi Non è nei nostri obiettivi affrontare UML nel suo complesso Ci concentreremo sui diagrammi delle classi che ci forniscono un linguaggio
Definizione 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
Programmazione Orientata agli Oggetti in Linguaggio Java
Programmazione Orientata agli Oggetti in Linguaggio Java Ruoli e Responsabilità: C# versione 1.1 Questo lavoro è concesso in uso secondo i termini di una licenza Creative Commons (vedi ultima pagina) G.
Ottava 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
Programmazione ad Oggetti: JAVA. Esercitazione
Programmazione ad Oggetti: JAVA Esercitazione Docente Ing. Mariateresa Celardo [email protected] Scrivere la classe Motorino che ha i seguenti attributi colore: una stringa indicante il colore
Oggetti 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
Soluzioni 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;
Gestione delle eccezioni in Java
Gestione delle eccezioni in Java Fondamenti di Informatica Ingegneria Gestionale Canale AL 1 Le eccezioni in Java Exception handling: insieme di costrutti e regole sintattiche e semantiche presenti nel
Tipi astratti di dato e loro realizzazione in Java
Unità 13 Tipi astratti di dato e loro realizzazione in Java Sommario Tipo astratto di dato Specifica di tipi astratti Astrazione di valori e astrazione di entità Realizzazione di tipi astratti in Java
Java Collection Framework. L14 JCF unina 1
Java Collection Framework L14 JCF unina 1 Java Collection Framework Prima di Java 2 erano disponibili poche classi container, soprattutto se riferite alla libreria STL del C++ Vector, Stack, Hashtable,
Struttura di un programma Java. Package. Uso dei package
Università degli Studi di Roma La Sapienza Corso di Laurea in Ingegneria dell Informazione (sede di Latina) Corso di Laurea in Ingegneria dell Informazione (consorzio Nettuno) Struttura di un programma
Fondamenti 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 [email protected] DII, Modena Via Vignolese (lab. Dottorandi
Esercizi 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
Main 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
Specifica 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.
Finestra.java. static String nomicolonne[] = {"ind.","cognome","nome","telefono","e-mail"}; //nomi delle colonne della tabella
import java.awt.*; import java.awt.event.actionevent; import java.awt.event.actionlistener; import java.awt.event.windowevent; import java.awt.event.windowlistener; import java.io.*; import java.util.*;
Esercitazioni 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
Esercitazioni 7 e 8. Bounded Buffer con sincronizzazione Java (1)
Università degli Studi della Calabria Corso di Laurea in Ingegneria Informatica A.A. 2001/2002 Corsi A e B Esercitazioni 7 e 8 Bounded Buffer con sincronizzazione Java (1) public class BoundedBuffer private
Organizzazione della lezione. Lezione 18 Remote Method Invocation - 6. (con callback) L accesso al registry per il rebind()
Organizzazione della lezione Lezione 18 Remote Method Invocation - 6 Vittorio Scarano Corso di Programmazione Distribuita (2003-2004) Laurea di I livello in Informatica Università degli Studi di Salerno
Gestione delle Eccezioni
Gestione delle Eccezioni Condizioni di Errore Una condizione di errore in un programma può avere molte cause Errori di programmazione Divisione per zero, cast non permesso, accesso oltre i limiti di un
SOMMARIO 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
Programmazione Java: Variabili membro, Metodi La parola chiave final
Programmazione Java: Variabili membro, Metodi La parola chiave final [email protected] http://www.di.univaq.it/romina.eramo/tlp Roadmap Definire una classe» Variabili membro» Metodi La parola chiave
ARRAY E STRINGHE. G. Frosini Slide 1
ARRAY E STRINGHE G. Frosini Slide 1 Array: VARIABILI ARRAY struttura dati costituita da elementi (anche nessuno, array vuoto) dello stesso tipo; tipo array: tipo degli elementi, non numero degli elementi;
Corso di Tecniche di Programmazione
Corso di Tecniche di Programmazione Corsi di Laurea in Ingegneria Informatica ed Automatica Anno Accedemico 003/004 Proff. Giuseppe De Giacomo, Luca Iocchi, Domenico Lembo Dispensa : Algoritmi di Ordinamento
Esempio: 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
Telematica II 15. Esercitazione/Laboratorio 5
Protocollo FTP FTP Client TCP control connection (port 21) FTP Server Telematica II 15. Esercitazione/Laboratorio 5 File System locale TCP data connection (port( 20) File System remoto La connessione di
Programmazione Java: Come contenere oggetti
Programmazione Java: Come contenere oggetti [email protected] http://www.di.univaq.it/romina.eramo/tlp Roadmap Introduzione ai contenitori Interfacce Implementazione Collection List Set Map Ordinamento»
Parola 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
Prova d Esame 07.04.2006 Compito A
DOMANDA 1 (6 punti) Si analizzi il codice seguente e si scriva l output prodotto dai metodi main public class General { public static String s1 = "Ciao"; protected int n; public General() { n = 1; public
Programmazione CORBA in Java
Programmazione CORBA in Java Ing. Andrea Santoro http://www.dis.uniroma1.it/~santoroa [email protected] (codice preparato dall ing. Alessandro Termini) Overview Naming Service Motivazioni Name Service
Prova d Esame 07.04.2006 Compito B
DOMANDA 1 (6 punti) Si analizzi il codice seguente e si scriva l output prodotto dai metodi main public class General { public static String s1 = "ciao"; protected int n; public General() { n = 3; public
Ingegneria 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
Programmazione a Oggetti Lezione 10. Ereditarieta
Programmazione a Oggetti Lezione 10 Ereditarieta Sommario Come definire sottoclassi Costruttori Abstract Classes Final Ereditarietà: promemoria Strumento tipico dell OOP per riusare il codice e creare
Corso Base. ActionSMS. Maurizio Cozzetto, Francesco Sarasini
Corso Base ActionSMS Maurizio Cozzetto, Francesco Sarasini Broadcast Receivers A broadcast receiver is a component that does nothing but receive and react to broadcast announcements (Intents). For a Broadcast
Flussi, lettori e scrittori
Flussi, lettori e scrittori Per sequenze di byte, InputStream, OutputStream e loro sottoclassi. Es: InputStream in = ; int next = in. read(); if (next!= -1) byte b = (byte) next; Per sequenze di caratteri,
7 Esercitazione (svolta): Callback. Polling. Java RMI: callback. Server. Server. Client. Client. due possibilità:
7 Esercitazione (svolta): due possibilità: Java RMI: callback Molte applicazioni richiedono un meccanismo publish/subscribe I partecipanti (client) necessitano di notifiche da parte del coordinatore (server)
UnicastRemoteObject. Massimo Merro Programmazione di Rete 103 / 124
UnicastRemoteObject Java RMI fornisce diverse classi base per definire server remoti: UnicastRemoteObject < RemoteServer < RemoteObject dove A < B significa che A è una sottoclasse di B. UnicastRemotObject
Esempi 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
