Laboratorio di Progettazione di Sistemi Software Design Patterns
|
|
|
- Erica Cinzia Baldini
- 9 anni fa
- Visualizzazioni
Transcript
1 TITLE Laboratorio di Progettazione di Sistemi Software Design Patterns Valentina Presutti (A-L) Riccardo Solmi (M-Z) 1
2 Indice degli argomenti Tipi di Design Patterns Creazionali Strutturali Comportamentali 2
3 Alcuni concetti Incapsulare Racchiudere in modo da mostrare all esterno solo quello che voglio. Gioco su package, classi e visibilità. Delegare Quando un metodo chiama un secondo metodo (di solito su un altro oggetto) per fargli fare il proprio lavoro. Inoltrare (forwards) Forma più debole di delega in cui la variabile this resta legata all oggetto chiamato. NB In Java si può solo inoltrare una chiamata. Indirezione Ogni volta che prima di fare la cosa richiesta ne faccio un altra (che in genere mi serve per capire come farla). Esempi: delega, inoltro e codice condizionale 3
4 Alcuni concetti /2 Variabilità: statica/dinamica dinamica significa che può cambiare durante l esecuzione (a runtime) mentre statica significa che può variare solo prima dell esecuzione (a compile time o a initialization time). Con/senza stato (statefull/stateless) Classi (e quindi oggetti) con o senza campi. Cambia la riusabilità degli oggetti Accoppiamento (coupling) Una classe/interfaccia è accoppiata ad un altra quando contiene un suo riferimento. Esempio: chiamata con parametro di un tipo non primitivo. 4
5 Design Patterns Definizione Un Design Pattern descrive un problema ricorrente di progettazione e uno schema di soluzione per risolverlo. NB Il termine Design nel nome non significa che riguardano solo la progettazione Serve a Progettare e implementare il Software in modo che abbia la flessibilità e le capacità di evolvere desiderate Dominare la complessità di un Sistema Software Catalogo Ogni Design Pattern ha un nome, un campo di applicabilità, uno schema di soluzione e una descrizione delle conseguenze della sua applicazione. 5
6 Esempi di Design Patterns 6
7 Design Patterns Design Patterns: progettare anticipando i cambiamenti Prima si progetta il Software poi lo si implementa. Massimizzare il riuso (senza ricompilazione) La compatibilità all indietro è spesso un obiettivo. Assumo di poter controllare solo una parte del codice sorgente. Progettare il Sistema in modo da anticipare i nuovi requisiti e i cambiamenti a quelli esistenti. 7
8 Design Patterns Uso Design Patterns per le esigenze attuali Riduco enfasi sulla progettazione iniziale Mi basta progettare una soluzione ragionevole non la migliore soluzione. Mi chiedo come evolverà il sistema ma mi basta sapere di poter aggiungere un certo tipo di flessibilità con il Refactoring Incorporare Design nei sorgenti Le scelte progettuali e le dipendenze devono essere il più possibile espresse nei sorgenti I commenti non sono un deodorante per rendere accettabile un codice illeggibile 8
9 Rischi e limiti dei Design Patterns Esistono dei trade-off Non esiste una combinazione di Patterns che mi dà il massimo di flessibilità e di facilità di evolvere. Un Design Pattern facilita alcuni sviluppi futuri a scapito di altri. Cambiare una scelta progettuale può essere costoso Rischio di sovra-ingegnerizzare Il codice diventa più flessibile e sofisticato di quanto serve. Quando scelgo i Patterns prima di iniziare ad implementare. Quando introduco i Patterns troppo presto. Costo computazionale La flessibilità di una soluzione costa ed è accompagnata da una maggiore complessità. Usare un Design Pattern per esigenze future è un costo 9
10 Limiti OO evidenziati dai Design Patterns Identità degli oggetti Spesso una entità del dominio viene rappresentata da un insieme di classi dell applicazione (object schizophrenia) Problema del significato di this. Problema della consistenza delle operazioni Incapsulamento dei dati La scomposizione di una entità in più classi mi obbliga a ridurre l incapsulamento dei dati. Rappresentazione indiretta Dato un programma, non è facile stabilire quali Design Pattern sono stati applicati. Parte delle informazioni di progettazione sono perse. 10
11 Dipendenze nel codice Scrivere un programma introduce dipendenze Comprendere le dipendenze che si introducono in modo da scegliere consapevolmente i Design Pattern. Le dipendenze contenute in una classe/interfaccia consistono nell insieme dei riferimenti (statici) ad altre classi/interfacce. I design pattern vengono classificati in base al tipo di dipendenze su cui agiscono in: creazionali, strutturali, comportamentali. Esempi di dipendenze: istanziazione oggetti, campi e metodi, variabili e parametri di tipi non primitivi 11
12 Design Patterns Creazionali Astraggono il processo di istanziazione Nascondo i costruttori e introduco dei metodi al loro posto Conseguenze: Incapsulano la conoscenza delle classi concrete usate Nascondono il modo in cui le istanze di queste classi vengono create e assemblate Espongono interfacce al posto di tipi concreti Esempi: Abstract Factory, Builder, Factory Method, Prototype, Singleton 12
13 Design Patterns Strutturali Descrivono come comporre classi e oggetti in strutture più grandi Si dividono in: basati su classi e basati su oggetti I primi usano l ereditarietà (statica) I secondi usano la composizione (anche dinamica) Conseguenze Aggiungono un livello di indirezione per disaccoppiare le due interfacce. Esempi: Adapter, Composite, Decorator, Proxy 13
14 Design Patterns comportamentali Riguardano algoritmi e l assegnamento di responsabilità tra oggetti Descrivono pattern di comunicazione tra oggetti. Per distribuire il comportamento usano l ereditarietà o la composizione. Conseguenze Alcuni incapsulano il comportamento in modo da poterlo variare anche dinamicamente Disaccoppiano il chiamante e il chiamato aggiungendo un livello di indirezione. Esempi: Command, Iterator, Observer, Template Method, Visitor 14
Design Patterns. Introduzione 2. Introduzione 3
Design Patterns Introduzione Design patterns: factory, singleton, adapter, composite, decorator, observer Introduzione I Design Patterns sono stati applicati per la prima volta nell architettura Per costruire
SOMMARIO DESIGN PATTERN
INTRODUZIONE AI DESIGN PATTERN INGEGNERIA DEL SOFTWARE Università degli Studi di Padova Dipartimento di Matematica Corso di Laurea in Informatica, A.A. 2014 2015 [email protected] 2 DESIGN PATTERN
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,
Design patterns in Java
tesi di laurea Anno Accademico 2012/13 relatore Ch.mo prof. Porfirio Tramontana candidato Luciano Amitrano Matr. 534/2042 Progettare SW a oggetti è difficoltoso I progettisti devono cercare di far coesistere
UML I diagrammi implementativi
Corso di Laurea Specialistica in Ingegneria Informatica Corso di Ingegneria del Software A. A. 2008 - UML I diagrammi implementativi E. TINELLI I diagrammi implementativi In UML 2.x esistono 3 tipi di
Lab 4: Design Patterns
Dept. of Computer Science Lab 4: Design Patterns Matteo Camilli [email protected] http://camilli.di.unimi.it Progettazione del Software a.a. 2014/15 1 La Saga delle Anatre 1) Creiamo interfaccia
Laboratorio di Progettazione di Sistemi Software Introduzione
Laboratorio di Progettazione di Sistemi Software Introduzione Valentina Presutti (A-L) Riccardo Solmi (M-Z) Indice degli argomenti Introduzione all Ingegneria del Software UML Design Patterns Refactoring
Ingegneria del Software
Ingegneria del Software Analisi Object Oriented ed Elementi di Programmazione OO Origini Le metodologie ad oggi nascono negli anni 70 ma si affermano solo nelgi anni 80 grazie alla nascita dei linguaggi
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)
Programmazione Java Avanzata PATTERN
Programmazione Java Avanzata PATTERN Anno 2011/2012 Pattern Una soluzione progettuale generale a un problema ricorrente Elementi per il riuso di software ad oggetti Vantaggiosi e obbligatori da usare Pattern
design pattern una soluzione progettuale generale a un problema ricorrente
DESIGN PATTERN DESIGN PATTERN Un design pattern può essere definito "una soluzione progettuale generale a un problema ricorrente". Esso non è una libreria o un componente di software riusabile, quanto
Corso di Algoritmi e Strutture dati Programmazione Object- Oriented in Java (Parte I)
Corso di Algoritmi e Strutture dati Programmazione Object- Oriented in Java (Parte I) Ing. Gianluca Caminiti Sommario ( OOP ) Programmazione Object-Oriented Incapsulamento, Ereditarietà, Polimorfismo Richiami
Ingegneria del Software 4. Introduzione a UML. Dipartimento di Informatica Università di Pisa A.A. 2014/15
Ingegneria del Software 4. Introduzione a UML Dipartimento di Informatica Università di Pisa A.A. 2014/15 e per i modelli iterativi analisi peliminare analisi e progettazione realizzazione Necessità di
OO design pattern. Design pattern: motivazioni
Design pattern: motivazioni OO design pattern La progettazione OO è complessa Progettare sw OO riusabile ed evitare (o, almeno, limitare) la riprogettazione è ancor più complesso I progettisti esperti
CORSO DI PROGRAMMAZIONE JAVA STANDARD + ENTERPRISE EDITION
CORSO DI PROGRAMMAZIONE JAVA STANDARD + ENTERPRISE EDITION 0 DURATA 200 ore CONTENUTI Oracle PL/SQL Introduzione al PL/SQL Cenni su SQL con utilizzo di SQL*PLUS Configurazione ambiente Developer DB Classi,
Progettazione! Progettazione! Progettazione! Progettazione!
Creare un oggetto specificandone la classe esplicitamente! Orienta ad una particolare implementazione invece che ad una interfaccia! Può complicare i cambiamenti futuri! E meglio creare oggetti indirettamente!
Riassunto: cos è la OOP? classi astratte, interfacce, classi interne. Scaletta. Figura con area()? Figura senza area()? Stefano Mizzaro 1.
OO in Java: classi astratte, interfacce, classi interne Stefano Mizzaro Dipartimento di matematica e informatica Università di Udine http://www.dimi.uniud.it/mizzaro [email protected] Programmazione,
Progettazione : Design Pattern Creazionali
Progettazione : Design Pattern Creazionali Alessandro Martinelli [email protected] 30 Novembre 2010 Progettazione : Design Pattern Creazionali Aspetti generali dei Design Pattern Creazionali
Prefazione. Capitolo 1 Sistemi di elaborazione 1
Prefazione XI Capitolo 1 Sistemi di elaborazione 1 1.1 Algoritmo 1 1.2 Esecuzione 3 1.3 Memoria 4 1.4 Calcolo meccanico 5 1.5 Capacità di calcolo 7 1.6 Computer 8 Domande di verifica 11 Esercizi 11 Capitolo
Ingegneria del Software. Introduzione ai pattern
Ingegneria del Software Introduzione ai pattern 1 Definizione di pattern [dal [dal vocabolario vocabolario Garzanti] Garzanti] Alcuni esempi: Pattern architetturale Pattern di circuito stampato Pattern
Informatica Generale Andrea Corradini I linguaggi di programmazione
Informatica Generale Andrea Corradini 17 - I linguaggi di programmazione Sommario Cos'è un linguaggio di programmazione? Una prospettiva storica: linguaggi di prima, seconda e terza generazione I paradigmi
Esercitazione sui Design Pattern
Esercitazione sui Design Pattern Pattern Creazionali Singleton Permette la creazione di una sola istanza della classe all interno dell applicazione Fornisce un metodo con cui ottenere l istanza Il costruttore
10. Design Patterns. Andrea Polini. Ingegneria del Software Corso di Laurea in Informatica. (Ingegneria del Software) 10. Design Patterns 1 / 36
10. Design Patterns Andrea Polini Ingegneria del Software Corso di Laurea in Informatica (Ingegneria del Software) 10. Design Patterns 1 / 36 Problemi Ci focalizziamo nelle problematiche riguardanti la
CONCETTI E ARCHITETTURA DI UN SISTEMA DI BASI DI DATI
CONCETTI E ARCHITETTURA DI UN SISTEMA DI BASI DI DATI Introduzione alle basi di dati (2) 2 Modelli dei dati, schemi e istanze (1) Nell approccio con basi di dati è fondamentale avere un certo livello di
UML. Il linguaggio UML e ArgoUML. Ingegneria dei sistemi software 2009/ /09/2009
UML Il linguaggio UML e ArgoUML 30/09/2009 Ingegneria dei sistemi software 2009/2010 [email protected] UML Unified Modeling Language una famiglia di notazioni grafiche standardizzate* orientata
Pattern software. [SAP] Chapter 13, Architectural Tactics and Patterns
Luca Cabibbo Architettura dei Sistemi Software dispensa asw310 marzo 2018 Each pattern describes a problem which occurs over and over again in our environment, and then describes the core of the solution
Indice. Prefazione. 3 Oggetti e Java 53
Prefazione xv 1 Architettura dei calcolatori 1 1.1 Calcolatori e applicazioni 1 1.1.1 Alcuni esempi di applicazioni 3 1.1.2 Applicazioni e interfacce 4 1.2 Architettura dei calcolatori 7 1.2.1 Hardware
DESIGN PATTERN CREAZIONALI INGEGNERIA DEL SOFTWARE INTRODUZIONE SINGLETON. Scopo dei design pattern creazionali
DESIGN PATTERN CREAZIONALI DESIGN PATTERN CREAZIONALI INGEGNERIA DEL SOFTWARE Università degli Studi di Padova Dipartimento di Matematica Corso di Laurea in Informatica, A.A. 2013 2014 [email protected]
RDD 2. Laboratorio di Ingegneria del Software. Andrea Bei
Laboratorio di Ingegneria del Software Andrea Bei Altri pattern GRASP Altri pattern GRASP Polymorphism Pure Fabrication, Indirection Protected Variations 2 Polymorphism Problema: Come gestire alternative
Lezione 3 Progettazione di siti
Lezione 3 Progettazione di siti Ingegneria dei Processi Aziendali Modulo 1 Servizi Web Unità didattica 1 Protocolli Web Ernesto Damiani Università di Milano Elementi base della progettazione di servizi
Programmazione. Prof. Marco Bertini
Programmazione Prof. Marco Bertini [email protected] http://www.micc.unifi.it/bertini/ Presentazione del corso Orario Mercoledì: 9:15-13:15, aule 113+114 Giovedì: 9:15-13:15, aula 002 Ricevimento:
