UML: Class Diagram 1 Corso IS I /03

Slides:



Advertisements
Presentazioni simili
Programmazione ad oggetti
Advertisements

Progettazione concettuale
Unified Modeling Language
Recupero debito quarto anno Primo incontro
Progettazione concettuale
Le base di dati database.
1 Astrazioni sui dati : Specifica ed Implementazione di Tipi di Dato Astratti in Java.
Le gerarchie di tipi.
LIP: 1 Marzo 2005 Classe Object e Vettori. Partiamo da Lesercizio dellultima esercitazione realizzato tramite array Vedremo come si puo fare in modo piu.
Principi di Programmazione Object-Oriented
Principi di Programmazione Object-Oriented
4 – Progettazione – Introduzione e Modello E-R
Basi di Dati prof. A. Longheu 4 – Progettazione – Introduzione e Modello E-R Cap. 5 Basi di dati Atzeni – Ceri – Paraboschi - Torlone.
Sistemi basati su conoscenza Basi di conoscenza: rappresentazione e ragionamento (2 - Reti semantiche, Frames) Prof. M.T. PAZIENZA a.a
Sistemi basati su conoscenza Basi di conoscenza: rappresentazione e ragionamento (2 - Reti semantiche, Frames) Prof. M.T. PAZIENZA a.a
ENTITÀ - RELAZIONE MODELLO ENTITÀ E ATTRIBUTI DOMINI RELAZIONI
1 Programmazione ad oggetti in Java E.Mumolo, DEEI
XML e DTD. –il "PROLOG contiene: dichiarazione della versione di XML; commenti (facoltativi); dichiarazione del DOCUMENT TYPE. –il "DOCUMENT INSTANCE.
Progettazione dei Sistemi Interattivi (A.A. 2004/05) - Lezione 4 1 Sulla realizzazione dellereditarietà 4 Ereditarietà: statica / dinamica 4 Binding: statico.
UML: Class Diagram Corso IS I /03
UML: Esempio “Briscola” Corso IS I /03
UML: Extension Mechanism Corso IS I /03 Gianna Reggio Versione 0.0.
Procedure e funzioni nei linguaggi di alto livello Lab Programmazione - turno /2006.
Dichiarazione di classi Programmazione Corso di laurea in Informatica.
1 Le gerarchie di tipi. 2 Supertipi e sottotipi 4 un supertipo –class –interface 4 può avere più sottotipi –un sottotipo extends il supertipo ( class.
Basi di dati 2002 EER Vogliamo aumentare lespressività degli Entity Model EER: Entity Model Esteso.
Lezione XI Laboratorio di Programmazione. Ereditarieta Fondamentale proprieta dei linguaggi OO. Permette di specificare un nuova classe derivata da unaltra.
Elementi di programmazione ad oggetti a. a. 2009/2010 Corso di Laurea Magistrale in Ingegneria Elettronica Docente: Mauro Mazzieri, Dipartimento di Ingegneria.
Elementi di programmazione ad oggetti a. a. 2009/2010 Corso di Laurea Magistrale in Ingegneria Elettronica Docente: Mauro Mazzieri, Dipartimento di Ingegneria.
Programmazione in Java (8)
AlgoLab - Ereditarieta' Ereditarietà e polimorfismo in Java Laboratorio di Algoritmi 02/03 Prof. Ugo de Liguoro.
LA PROGETTAZIONE DELLE BASI DI DATI
UML: Collaboration diagram Corso IS I /03 Gianna Reggio Versione 1.0.
Enumerazioni e Classi 1. Enumerazioni Permettono di definire nuovi tipi che consistono in un insieme di valori costanti (ognuno con un nome) – Migliorano.
Il linguaggio UML Luca Lista.
ISTITUTO STATALE DI ISTRUZIONE SUPERIORE F. ENRIQUES CORSO JAVA – PROVA INTERMEDIA DEL 12 MARZO 2007 NOME: COGNOME: ________________________________________________________________________________.
Astrazione procedurale ed eccezioni
Le variabili in Java Nella programmazione tradizionale, una variabile è una porzione di memoria in cui è immagazzinato un certo tipo di dato. Per esempio.
Briscola.
Programmazione ad oggetti
Incapsulamento e information hiding
Diagramma delle Classi
Ereditarieta’. Contenuti Introduciamo un meccanismo fondamentale di Java: l’ereditarieta’ Permette di estendere classi gia’ definite (ovvero di definire.
1 Osservazioni Generali Struttura di programma Gerarchia di classi: overloading, overriding, e dispatching Analisi ed esecuzione Modificabilità e condivisione.
Fondamenti di Informatica II Ingegneria Informatica Prof. M.T. PAZIENZA a.a – 3° ciclo.
1 Tipi di Dato §descrittori, tipi, controllo e inferenza dei tipi §specifica (semantica) e implementazione di tipi di dato l implementazioni “sequenziali”
Fondamenti di Informatica 2 Ingegneria Informatica Docente: Giovanni Macchia a.a
1 FONDAMENTI DI INFORMATICA II Ingegneria Gestionale a.a ° Ciclo Alberi.
Fondamenti di informatica Oggetti e Java Luca Cabibbo Luca Cabibbo – Fondamenti di informatica: Oggetti e Java Copyright © 2004 – The McGraw-Hill Companies.
1 Gerarchie e polimorfismo: liste. 2 Generalizzare le liste di interi  List 4 lista di oggetti –non modificabile 4 vorremo poi definire un sottotipo.
LIP: 9 Maggio Esercizi Riprendiamo un esercizio proposto Definire un tipo di dato Persona che definisce oggetti che rappresentano le informazioni.
1 Progettare un Tipo di Dato Astratto. 2 Scelte di Progetto (astrazione) 4 Caratteristiche degli oggetti –Modificabilità 4 Scelta delle operazioni –Realizzare.
Programmazione in Java. Classi I programmi in Java consistono di classi. Le classi consentono di definire: collezioni di procedure (metodi statici) tipi.
Esercitazione del 7 marzo 2008 Ereditarieta’. Esercizio: soluzione Implementare la seguente specifica che definisce un tipo di dato Libro.
UML: Constraints-OCL Corso IS I /03
Cose nuove di Java (prima a chiacchiera, poi formalmente)
LIP: 2 Maggio 2008 Classi Astratte. Cos’e’ una Classe Astratta una classe astratta e’ un particolare tipo di classe permette di fornire una implementazione.
Ereditarieta’. Contenuti Introduciamo un meccanismo fondamentale di Java: l’ereditarieta’ Permette di estendere classi gia’ definite (ovvero di definire.
UML: Introduzione Corso IS I /03 Gianna Reggio Versione 0.0.
Ereditarieta’. Contenuti Introduciamo un meccanismo fondamentale di Java: l’ereditarieta’ Permette di estendere classi gia’ definite (ovvero di definire.
Ingegneria del software Modulo 1 - Introduzione al processo software Unità didattica 4 - Progettazione del software Ernesto Damiani Università degli Studi.
Esercitazione del 9 marzo 2007 Ereditarieta’. Richiami Definire sottoclassi (ereditarieta’) Overriding Specificatori di accesso (private, protected) Principio.
Corso di Laurea Ingegneria Informatica Fondamenti di Informatica
Eprogram informatica V anno.
Cloud informatica V anno.
Corso di Algoritmi e Strutture Dati con Laboratorio Richiami di Java – parte II.
28/12/2001package 1 Package Pacchetti e interfacce.
Introduzione all’Ereditarietà Pietro Palladino. Richiami UML Classe: descrizione di un insieme di oggetti software con caratteristiche simili Definisce.
Transcript della presentazione:

UML: Class Diagram 1 Corso IS I - 2002/03 Gianna Reggio Versione 0.0

Class Diagram definisce molti usi le classi (degli oggetti utilizzati in un certo modello) le loro features attributi operazioni/metodi le loro mutue relazioni esistenza di associazioni tra i loro elementi specializzazione/inheritance aggregazione/composizione molti usi modellazione concettuale specifica del design descrizione dell’implementazione …...

Starting point basato sugli usuali concetti OO ispirato da classe oggetto specializazzione …. ispirato da diagrammi entity-relationship dal mondo database

Classe nome della classe compartimento degli attributi Carta seme: String valore: Int ritornaValore(): Int compartimento degli attributi compartimento delle operazioni permesso Carta seme: String valore: Int Carta ritornaValore(): Int Carta compartimento mancante: nessuna informazione su i suoi elementi compartimento vuoto: nessun elemento di quel tipo Carta

visibilità di attributi/operazioni private (-) visibile solo dentro la classe public (+) visibile solo dentro la classe e quelle associate ad essa (legate da associazioni [vediamo dopo]) protected (#) visibile solo dentro la classe e le sue sottoclassi (specializzazioni [vediamo dopo])

tipi di attributi ed operazioni tipi predefiniti nel corso useremo quelli di OCL (prossimamente) Int, String, Bool, Real, enumeration, … ogni classe definita nel modello corrente

Attributi - valore[0..1]: Int = 0 visibilità omessa = private molteplicità - valore[0..1]: Int = 0 valore iniziale tipo nome visibilità omessa = private molteplicità omessa = [1] tipo omesso = non importa quale è

Operazioni + cambiaVal(nVal:Int) + ritornaValore(): Int visibilità + cambiaVal(nVal:Int) + ritornaValore(): Int parametri nessun parametro nome ritorna un valore visibilità omessa = public parametri per valore e per riferimento il nome può essere omesso

Metodi È possibile specificare un’operazione dandone un “body” per mezzo di un method Carta seme: String valore: Int ritornaValore(): Int { if (valore is not empty) then return self.valore else return 0 }

Associazioni tra classi, in genere binarie relazione tra le istanze di tali classe vari ruoli, dipende dall’uso del class diagram Carta Seme Mazzo tipo 10..* 1 nomi dei ruoli haTipo carteDelTipo nome contiene * 1..54 molteplicità

Aggregazione/Composizione associazioni speciali per indicare che gli oggetti di una classe sono fatti/o contengono oggetti di un’altra aggregazione Carta Mazzo contiene 1..54 parti aggregato composizione richiede coincidenza delle vite dell’aggregato e delle parti partecipanti Giocatore Partita 4 parti aggregato

Generalizzazione (Specializzazione) Giocatore Mazziere generalizzato (superclasse, supertipo) specializzato (sottoclasse, sottotipo) qualunque numero di livelli gerarchia di tipi inheritance degli attributi e delle operazioni della superclasse interpretazione dipende dall’uso del class diagram

Specializzazione multipla Giocatore Mazziere Normale {predefined constraint} predefined constraint può essere complete/incomplete ogni sottoclasse è/non è stata specificata disjoint/overlapping sottoclassi sicuramente disgiunte/possibilmente sovrapposte