Pila 1. Pila 2. Pila 4. Pila 3. Attenti all ordine! public: Pila() { size=initialsize; defgsize =initialsize; marker=0; contenuto=new int[size]; }

Dimensione: px
Iniziare la visualizzazioe della pagina:

Download "Pila 1. Pila 2. Pila 4. Pila 3. Attenti all ordine! public: Pila() { size=initialsize; defgsize =initialsize; marker=0; contenuto=new int[size]; }"

Transcript

1 1 Pila 1 2 Pila 2 public class Pila { protected int size; protected int defgsize; protected int marker; protected int contenuto[]; final int initialsize=3; class Pila { protected: int size; int defgsize; int marker; int * contenuto; const int initialsize=3; public { size=initialsize; defgsize=initialsize; public Pila(int s) { size=s; defgsize =s; { size=initialsize; defgsize =initialsize; Pila(int s) { size=s; defgsize =s; ~ { delete [](contenuto); 3 Attenti all ordine! Pila 3 private void cresci(){ size+=dfg; int temp[]=new int[size]; for (int k=0; k<=marker;k++) temp[k]=contenuto[k]; contenuto=temp; private: void Pila::cresci(){ size+=dfg; int * temp=new int[size]; for (int k=0; k<=marker;k++) temp[k]=contenuto[k]; delete [](contenuto); contenuto=temp; 4 public void inserisci(int k) { if (size==marker) cresci(); contenuto[marker]=k; marker++; int estrai() { assert(marker>0):"pila vuota"; return contenuto[--marker]; Pila 4 void inserisci(int k){ if (size==marker) cresci(); contenuto[marker]=k; marker++; int estrai() { assert(marker>0); return contenuto[--marker]; 1

2 5 main fuori dalla classe Pila 5 Pila *p=new Pila; cout<<p->estrai()<<endl; public static void main(string[] a) { Pila p=new Pila; p.inserisci(k); System.out.println(p.estrai()); main dentro la classe 6 Package Una classe per file Altre differenze Separazione tra interfaccia (.h) e implementazione (.cpp) Pila::{ ecc. Preprocessore: #include #define #ifdef 7 Catch up Concatenamento dei costruttori Polimorfismo upcast/downcast Gerarchia standars (Object ) Modificatori Arrays di oggetti Type fuctionality (equals, clone, tostring) 8 public class Coda extends Pila{ public int estrai() { assert(marker>0):"coda vuota"; int retval=contenuto[0]; for (int k=1;k<marker;k++;) contenuto[k-1]=contenuto[k]; marker--; return retval; class Coda:public Pila{ int estrai(); int Coda::estrai() { assert(marker>0); int retval=contenuto[0]; for (int k=1;k<marker;k++;) contenuto[k-1]=contenuto[k]; marker--; return retval; 2

3 Pila * p=new Pila; cout<<p->estrai()<<" "; cout<<endl; Coda * c=new ; c-> inserisci(k); cout<<c->estrai ()<<" "; Pila * p=new Pila; cout<<p->estrai()+" "; cout<<endl; Coda * c=new ; c-> inserisci(k); cout<<c->estrai ()+" "; 11 In Java il costruttore della sottoclasse invoca il costruttore void della superclasse, a meno si usare super. Che succede in C++? Costruttori Pila:: { cout<<" <<endl; size=initialsize; defgsize =initialsize; Pila::Pila(int s) { cout<<"pila(int) <<endl; size=s; defgsize =s; Coda:: { cout<<" <<endl; Coda::Coda(int s) { cout<<"coda(int) <<endl; 12 Coda(int) Costruttori Coda *c=new Coda; Coda *c=new Coda(3); 3

4 13 Costruttori 14 Distruttori finalize() Costrutto equivalente al super di Java Pila(int) Coda(int) Coda:: { cout<<" <<endl; Coda::Coda(int s):pila(s) { cout<<"coda(int) <<endl; Coda *c=new ; Coda *c=new Coda(3); public class Pila{ System.out.println("P"); public class Coda extends Pila{ System.out.println("C"); public static void main(string []a){ Coda c=new ; c=null; System.gc(); C 15 Distruttori finalize() public class Pila{ System.out.println("P"); public class Coda extends Pila{ System.out.println("C"); super.finalize(); public static void main(string []a){ Coda c=new ; c=null; System.gc(); C P 16 In Java l implementazione di finalize() è rara, e la sua chiamata avviene automaticamente. In Java il finalize della sottoclasse NON chiama il finalize della superclasse, a meno di usare super. Che succede in C++? Distruttori Pila::~ { cout<<"~pila <<endl; delete [] contenuto; Coda::~ { cout<<"~ <<endl; 4

5 17 Distruttori 18 Distruttori virtuali ~ ~ ~ ~ Pila *c=new Pila; Coda *c=new Coda; Pila *c=new Coda; Class Pila{ virtual Pila::~ ; Pila::~ { cout<<"~pila <<endl; delete [] contenuto; Coda::~ { cout<<"~ <<endl; 19 Distruttori virtuali 20 Polimorfismo ~ ~ Coda *c=new Coda; Dichiarate SEMPRE virtual il distruttore ~ ~ Pila * p; p=new ; p-> inserisci(k); cout<<p->estrai()<<endl; 5

6 21 Polimorfismo- virtual ~ ~ class Pila{ virtual int estrai(); Pila * p; p=new ; cout<<p->estrai()<<endl; 6

3LOD 3LOD. public class Pila { class Pila { protected: int size; int defgsize; int marker; int * contenuto; const int initialsize=3;

3LOD 3LOD. public class Pila { class Pila { protected: int size; int defgsize; int marker; int * contenuto; const int initialsize=3; public class Pila { 3LOD class Pila { protected int size; protected int defgsize; protected int marker; protected int contenuto[]; final int initialsize=3; protected: int size; int defgsize; int marker;

Dettagli

La Pila in Java - 1. package strutture; public class Pila { int size; int defaultgrowthsize; int marker; int contenuto[];

La Pila in Java - 1. package strutture; public class Pila { int size; int defaultgrowthsize; int marker; int contenuto[]; La Pila in Java - 1 package strutture; public class Pila { int size; int defaultgrowthsize; int marker; int contenuto[]; Pila(int initialsize) { size=initialsize; defaultgrowthsize=initialsize; marker=0;

Dettagli

Pila.h. #define DEFAULTGROWTHSIZE 5 struct Pila { int size; int marker; int * contenuto; } ;

Pila.h. #define DEFAULTGROWTHSIZE 5 struct Pila { int size; int marker; int * contenuto; } ; 1 #define DEFAULTGROWTHSIZE 5 struct Pila { int size; int marker; int * contenuto; ; Pila.h Pila * crea(int initialsize) ; void distruggi(pila * s) ; Pila * copia(pila * from) ; void cresci(pila *s, int

Dettagli

Il nostro esempio guida: La costruzione di uno stack

Il nostro esempio guida: La costruzione di uno stack 1 Il nostro esempio guida: La costruzione di uno stack 2 Costruiamo uno stack stackapplet.html 1 3 #include #include #define DEBUG struct Pila { int size; int defaultgrowthsize;

Dettagli

#include <iostream.h> #include <cassert> #define DEBUG. contenuto. struct Pila { int size; int defaultgrowthsize; int marker; int * contenuto; } ;

#include <iostream.h> #include <cassert> #define DEBUG. contenuto. struct Pila { int size; int defaultgrowthsize; int marker; int * contenuto; } ; #include #include #define DEBUG struct Pila { int defaultgrowthsize; ; size marker contenuto 16 5 12 2 Pila * crea(int initialsize) { //crea uno Pila cout

Dettagli

Pila.h versione 6. class Pila { private: int marker; int * contenuto; public:

Pila.h versione 6. class Pila { private: int marker; int * contenuto; public: 1 Pila.h versione 6 struct Pila { private: int size; int defaultgrowthsize; int marker; int * contenuto; void cresci(int increment); public: Pila(int initialsize) ; Pila(); ~Pila() ; void copy(pila * to)

Dettagli

Determinazione del tipo

Determinazione del tipo 1 Determinazione del tipo Point NamedPoint public static void main(string a[]){ Point p; // leggi k if (k==1) p=new Point(2,2); else p=new NamedPoint(3,3, A ); // p.getname(); SBAGLIATO! if (p instanceof

Dettagli

Classi Wrapper. int Integer float Float char Char byte Byte double Double. classe "wrapper"

Classi Wrapper. int Integer float Float char Char byte Byte double Double. classe wrapper 1 Classi Wrapper classe "wrapper" int Integer float Float char Char byte Byte double Double Generano oggetti che hanno come variabile di istanza un tipo di dato primitivo con nome uguale Integer int Float

Dettagli

Elementi di C++ di base. Arrays (vettori) Gli array sono collezioni di elementi omogenei

Elementi di C++ di base. Arrays (vettori) Gli array sono collezioni di elementi omogenei 1 Elementi di C++ di base Arrays (vettori) 2 Array Gli array sono collezioni di elementi omogenei int valori[10]; char v[200], coll[4000]; Un array di k elementi di tipo T in è un blocco di memoria contiguo

Dettagli

Esercizio: Costruite una Coda analoga alla Pila

Esercizio: Costruite una Coda analoga alla Pila 1 Esercizio: Costruite una Coda analoga alla Pila 1 2 Pila e Coda IN OUT CODA IN OUT PILA 3 Trasformare la Pila in Coda int estrai() { assert(marker>0):"invalid marker"; int retval=contenuto[0]; for (int

Dettagli

SEZIONE 2 Introduzione al copy constructor e ad operator overloading

SEZIONE 2 Introduzione al copy constructor e ad operator overloading SEZIONE 2 Introduzione al copy constructor e ad operator overloading void f(pila s) { s.estrai(); s.inserisci(3); cout

Dettagli

Overloading - Overriding

Overloading - Overriding 1 Overloading - Overriding Overloading: Funzioni con uguale nome e diversa firma possono coesistere. move(int dx, int dy) move(int dx, int dy, int dz) Overriding: Ridefinizione di una funzione in una sottoclasse

Dettagli

Laboratorio di Sistemi Polimorfismo Java. Prerequisiti: per la comprensione dell'articolo è necessario conoscere il concetto di Ereditarietà in Java.

Laboratorio di Sistemi Polimorfismo Java. Prerequisiti: per la comprensione dell'articolo è necessario conoscere il concetto di Ereditarietà in Java. Prerequisiti: per la comprensione dell'articolo è necessario conoscere il concetto di Ereditarietà in Java. Di solito se abbiamo la struttura di una classe con gli attributi e i metodi possiamo istanziare

Dettagli

Esercizio: Costruite una Coda analoga alla Pila

Esercizio: Costruite una Coda analoga alla Pila 1 Esercizio: Costruite una Coda analoga alla Pila 1 2 Pila e Coda IN OUT CODA IN OUT PILA 3 Trasformare la Pila in Coda int estrai() { assert(marker>0):"invalid marker"; int retval=contenuto[0]; for (int

Dettagli

Metodi static. Esempio. public class Financial { { return (p / 100) * a; } //... }

Metodi static. Esempio. public class Financial { { return (p / 100) * a; } //... } Static Metodi static Esempio public class Financial public static double percentof(double p, double a) return (p / 100) * a; //... Metodi static Altri esempi ben noti main() i metodi della classe Math

Dettagli

Sezione: Upcast - downcast

Sezione: Upcast - downcast 1 Sezione: Upcast - downcast Upcast & downcast 2 public class Test { public static void main(string a[]) { new Test(); Test() { A a; cast B b = new B(); OK: upcast implicito a=b; NO: "method f2 not found

Dettagli

Programmazione orientata agli oggetti La classe Object, metodi e classi final, this. Object

Programmazione orientata agli oggetti La classe Object, metodi e classi final, this. Object Programmazione orientata agli oggetti La classe, metodi e classi final, this 1 La classe Negli esempi fatti nella prima parte del corso abbiamo definito alcune classi, per esempio Counter e Orologio, senza

Dettagli

Programmazione orientata agli oggetti La classe Object, metodi e classi final, this. Object

Programmazione orientata agli oggetti La classe Object, metodi e classi final, this. Object Programmazione orientata agli oggetti La classe, metodi e classi final, this 1 La classe Negli esempi fatti nella prima parte del corso abbiamo definito alcune classi, per esempio Counter e Orologio, senza

Dettagli

Programmazione 2 - Marco Ronchetti. Fondamenti di Java. Fac.Scienze Università di Trento. Static

Programmazione 2 - Marco Ronchetti. Fondamenti di Java. Fac.Scienze Università di Trento. Static 1 Fondamenti di Java Static 2 Modificatori: static Variabili e metodi associati ad una Classe anziche ad un Oggetto sono definiti static. Le variabili statiche servono come singola variabile condivisa

Dettagli

Programmazione in Java (I modulo) Lezione 20: Ereditarietà

Programmazione in Java (I modulo) Lezione 20: Ereditarietà Programmazione in Java (I modulo) Lezione 20: Ereditarietà Ereditarietà (Inheritance) Il programmatore definisce una classe generale In seguito definisce una classe più specifica Aggiungo soltanto nuovi

Dettagli

Corso di Laurea in Bioinformatica Dipartimento di Informatica - Università di Verona

Corso di Laurea in Bioinformatica Dipartimento di Informatica - Università di Verona di Corso di Laurea in Bioinformatica Dipartimento di Informatica - Università di Verona su Sommario di su di di di su Astrazione sugli oggetti di su Il concetto di classe Classe: realizza l astrazione

Dettagli

punto.x di Java equivale a punto->x del C++ In Java gli oggetti sono accessibili SOLO per referenza

punto.x di Java equivale a punto->x del C++ In Java gli oggetti sono accessibili SOLO per referenza Confronto dell operatore new in C++: Point * punto = new Point(10,10);! in Java: Point punto = new Point(10,10); punto.x di Java equivale a punto->x del C++ In Java gli oggetti sono accessibili SOLO per

Dettagli

Paradigmi della PO. Incapsulamento. Ereditarietà. Polimorfismo. Software per TLC - AA 2008/2009 1

Paradigmi della PO. Incapsulamento. Ereditarietà. Polimorfismo. Software per TLC - AA 2008/2009 1 Incapsulamento Paradigmi della PO Ereditarietà Polimorfismo Software per TLC - AA 2008/2009 1 Incapsulamento Una classe contiene dati e metodi Filosofia Ai dati si accede solo attraverso i metodi I metodi

Dettagli

Esempi al calcolatore su: 1) Costruttori ed ereditarietà 2) Subtyping e polimorfismo

Esempi al calcolatore su: 1) Costruttori ed ereditarietà 2) Subtyping e polimorfismo Esempi al calcolatore su: 1) 2) Subtyping e polimorfismo 1 Esempio 1: 2 Introduzione Java prevede due automatismi legati ai costruttori: Se una classe non ha costruttori viene creato automaticamente il

Dettagli

Ancora sulle Classi in C++ e Java. this

Ancora sulle Classi in C++ e Java. this Ancora sulle Classi in C++ e Java this Classe: riepilogo gestione memoria ogg1: oggetto di invocazione del metodo ogg: parametro fornito al metodo!"# ogg1 ogg2 ogg metodoa metodob varv varw varx varv varw

Dettagli

Istruzioni. Il codice Java delle domande non mostra gli import, che si assumono essere correttamente presenti.

Istruzioni. Il codice Java delle domande non mostra gli import, che si assumono essere correttamente presenti. Istruzioni Staccare questo foglio dal resto del blocchetto, ed utilizzarlo per segnare le risposte (sul retro di questa pagina). Segnare SUBITO nome, cognome e numero di matricola negli appositi spazi.

Dettagli

Concetti Base Encapsulation ed Ereditarietà Programmare con l Ereditarietà. Java: Ereditarietà. Damiano Macedonio

Concetti Base Encapsulation ed Ereditarietà Programmare con l Ereditarietà. Java: Ereditarietà. Damiano Macedonio Dipartimento di Informatica, Università degli Studi di Verona Corso di Programmazione per Bioformatica Introduzione Ereditarietà in Sintesi È uno dei concetti chiave della programmazione orientata agli

Dettagli

tipo identificatore Operatore di creazione

tipo identificatore Operatore di creazione Tipi di dato derivati (reference data) n Java, come tutti i linguaggi OO, permette di definire NUOVI TIPI DI DATO (classi). n Alcuni tipi di dato (classi) sono predefinite: n ad esempio le stringhe. (String)

Dettagli

C++ Copy Constructor

C++ Copy Constructor C++ Copy Constructor Versione 1 #include using namespace std; class Line{ public: Line( int len ); ~Line(); ; // simple constructor // destructor Member functions definitions Line::Line(int

Dettagli

Programmazione orientata agli oggetti La classe Object, metodi e classi final, this. Object

Programmazione orientata agli oggetti La classe Object, metodi e classi final, this. Object Programmazione orientata agli oggetti La classe, metodi e classi final, this 1 La classe Negli esempi fatti nella prima parte del corso abbiamo definito alcune classi, per esempio Counter e Orologio, senza

Dettagli

Laboratorio di programmazione

Laboratorio di programmazione Laboratorio di programmazione Lezione X Tatiana Zolo tatiana.zolo@libero.it 1 Proprietà fondamentale dei linguaggi object-oriented. Classe A classe base (o superclasse) classe da cui si eredita Classe

Dettagli

Programmazione in Java (I modulo) Lezione 21: Classi derivate e l'operatore instanceof Riscrivere il metodo tostring() Riscrivere il metodo equals()

Programmazione in Java (I modulo) Lezione 21: Classi derivate e l'operatore instanceof Riscrivere il metodo tostring() Riscrivere il metodo equals() Programmazione in Java (I modulo) Lezione 21: Classi derivate e l'operatore instanceof Riscrivere il metodo tostring() Riscrivere il metodo equals() Ereditarietà (Inheritance) RIASSUMIAMO DALLA SCORSA

Dettagli

Fondamenti di Java. Soluzione esercizio hashcode

Fondamenti di Java. Soluzione esercizio hashcode Fondamenti di Java Soluzione esercizio hashcode Esercizio Definire una classe con una hashcode corretta. Aggiungere delle istanze "uguali" a un set, e controllare la dimensione del set ottenuto. Vi torna

Dettagli

Richiami di C++ di base

Richiami di C++ di base 1 Richiami di C++ di base 2 Il modello di memoria stack memoria allocata dalle funzioni (Variabili automatiche) heap uninitialized data initialized read/write data initialized read/only data text memoria

Dettagli

Sommario. I Uso degli oggetti 39

Sommario. I Uso degli oggetti 39 Questo è l'indice del libro, in cui sono evidenziati i paragrafi corrispondenti agli argomenti trattati nel corso e che costituiranno il programma d'esame. Alcuni argomenti sono stati trattati nelle lezioni

Dettagli

Concetti principali Ereditarietà e (overriding) di metodi. Ereditarietà e costruttori Livelli di accesso protected e package La classe Object

Concetti principali Ereditarietà e (overriding) di metodi. Ereditarietà e costruttori Livelli di accesso protected e package La classe Object Ereditarietà Concetti principali Ereditarietà e (overriding) di metodi Dynamic dispatch e polimorfismo Ereditarietà e costruttori Livelli di accesso protected e package La classe Object metodi tostring,

Dettagli

Esempi al calcolatore su: 1) Costruttori ed ereditarietà 2) Subtyping e Polimorfismo

Esempi al calcolatore su: 1) Costruttori ed ereditarietà 2) Subtyping e Polimorfismo Esempi al calcolatore su: 1) 2) Subtyping e Polimorfismo 1 Esempio 1: 2 Introduzione Java prevede due automatismi legati ai costruttori: Se una classe non ha costruttori viene creato automaticamente il

Dettagli

Gerarchia delle classi Classi astratte Interfacce (Eccezioni) Laboratorio di Programmazione - Esercitazio 1

Gerarchia delle classi Classi astratte Interfacce (Eccezioni) Laboratorio di Programmazione - Esercitazio 1 Gerarchia delle classi Classi astratte Interfacce (Eccezioni) Laboratorio di Programmazione - Esercitazio 1 Gerarchia delle classi Una sottoclasse eredita metodi, variabili, etc. dalla superclasse... Per

Dettagli

Ereditarietà. Unità 9. Domenico Daniele Bloisi. Corso di Programmazione e Metodi Numerici Ingegneria Aerospaziale BAER

Ereditarietà. Unità 9. Domenico Daniele Bloisi. Corso di Programmazione e Metodi Numerici Ingegneria Aerospaziale BAER Corso di Programmazione e Metodi Numerici Ingegneria Aerospaziale BAER Domenico Daniele Bloisi Docenti Metodi Numerici prof. Vittoria Bruni vittoria.bruni@sbai.uniroma1.it Programmazione prof. Domenico

Dettagli

Ereditarietà (ultima)

Ereditarietà (ultima) Ereditarietà (ultima) Classi astratte Un ibrido tra classi e interfacce Hanno alcuni metodi implementati normalmente, altri astratti Un metodo astratto non ha implementazione abstract class AccountTransaction...

Dettagli

Ereditarietà (ultima)

Ereditarietà (ultima) Ereditarietà (ultima) Classi astratte Un ibrido tra classi e interfacce Hanno alcuni metodi implementati normalmente, altri astratti Un metodo astratto non ha implementazione abstract class AccountTransaction

Dettagli

OCA JAVA 7 SE PROGRAMMER I DOCENTE: DOTT. FAUSTO DELL ANNO

OCA JAVA 7 SE PROGRAMMER I DOCENTE: DOTT. FAUSTO DELL ANNO CENTRO STUDI ULISSE Via Buccino, n. 22 - C.a.p. 84018 - Scafati (SA) Tel. Fax. 081.19970299-339.2365416-349.4152010 E-mail: info@centrostudiulisse.it - www.centrostudiulisse.it OCA JAVA 7 SE PROGRAMMER

Dettagli

Ingegneria del Software

Ingegneria del Software Ingegneria del Software Java Classi Dichiarazione di Classi [Doc comment] [Modifiers] class ClassName [ extends SuperClassName] [ implements InterfaceName [, InterfaceName]...] {ClassBody Doc comment commento

Dettagli

Esempio 2: Subtyping

Esempio 2: Subtyping Esempio 2: Subtyping 22 Subclassing e subtyping Fino ad ora abbiamo trattato l ereditarietà come strumento che consente il riuso flessibile di classi già esistenti mediante l aggiunta o la ridefinizione

Dettagli

Laboratorio di Sistemi Ereditarietà Java

Laboratorio di Sistemi Ereditarietà Java L'ereditarietà consente allo sviluppatore di riutilizzare il codice già scritto creando sottoclassi a partire da classi già definite. La sottoclasse eredita tutti gli attributi e tutti i metodi definiti

Dettagli

RIUSABILITÀ L OBIETTIVO

RIUSABILITÀ L OBIETTIVO RIUSABILITÀ Si vuole riusare tutto ciò che può essere riusato (componenti, codice, astrazioni) Non è utile né opportuno modificare codice già funzionante e corretto il cui sviluppo ha richiesto tempo (anni-uomo)

Dettagli

Ereditarietà: concetti di base

Ereditarietà: concetti di base : concetti di base L ereditarietà è uno dei concetti base della programmazione ad oggetti Concetto di base: l ereditarietà permette di usare una classe precedentemente definita per la definizione di una

Dettagli

OCA JAVA 7 SE PROGRAMMER I DOCENTE: DOTT. FAUSTO DELL ANNO

OCA JAVA 7 SE PROGRAMMER I DOCENTE: DOTT. FAUSTO DELL ANNO CENTRO STUDI ULISSE Via Buccino, n. 22 - C.a.p. 84018 - Scafati (SA) Tel. Fax. 081.19970299-339.2365416-349.4152010 E-mail: info@centrostudiulisse.it - www.centrostudiulisse.it OCA JAVA 7 SE PROGRAMMER

Dettagli

Obiettivi. Comprendere i vantaggi offerti dal meccanismo dell ereditarietà Attivare processi di astrazione e specializzazione.

Obiettivi. Comprendere i vantaggi offerti dal meccanismo dell ereditarietà Attivare processi di astrazione e specializzazione. Obiettivi Unità B2 Gli oggetti: concetti avanzati Comprendere i vantaggi offerti dal meccanismo dell ereditarietà Attivare processi di astrazione e specializzazione Ereditarietà L ereditarietà permette

Dettagli

Varie: final, visibilità, parametri di ingresso

Varie: final, visibilità, parametri di ingresso Varie: final, visibilità, parametri di ingresso Classi e metodi final È possibile impedire la creazione di sottoclassi di una certa classe definendola final Esempio: final class C {... class C1 extends

Dettagli

Esempi in Java di program.ne O-O

Esempi in Java di program.ne O-O Esempi in Java di program.ne O-O Ereditarietà Polimorfismo statico e dinamico Esercitazione laboratorio Interfaccia Comparable e Comparator 1 Gerarchia di ereditarietà Persona IS_A Docente Studente Tecnico

Dettagli

Uguaglianza e Identità. (no, non avete sbagliato corso )

Uguaglianza e Identità. (no, non avete sbagliato corso ) 1 Uguaglianza e Identità (no, non avete sbagliato corso ) Fondamenti di Java Che vuol dire "uguaglianza"? Che vuol dire "Identità"? Che differenza c è? Uguaglianza public class Test { public static void

Dettagli

La classe java.lang.object

La classe java.lang.object La classe java.lang.object In Java: Gerarchia di ereditarietà semplice Ogni classe ha una sola super-classe Se non viene definita esplicitamente una super-classe, il compilatore usa la classe predefinita

Dettagli

Corso di Progettazione del Software

Corso di Progettazione del Software T. Mancini & M. Scannapieco S.JOO.3 Java: le classi Object e Class February 2, 2008 p. 1/12 Università degli Studi di Roma La Sapienza Facoltà di Ingegneria Corso di Laurea in Ingegneria Gestionale Corso

Dettagli

Informatica e Laboratorio di Programmazione C++ Object Oriented Programming Alberto Ferrari

Informatica e Laboratorio di Programmazione C++ Object Oriented Programming Alberto Ferrari Informatica e Laboratorio di Programmazione C++ Object Oriented Programming Alberto Ferrari oggetti o in C++ la definizione della classe è separata dalla implementazione dei metodi o definizione fornita

Dettagli

CloneNotSupportedException clone() Object clone() protected native Object clone() throws CloneNotSupportedException this

CloneNotSupportedException clone() Object clone() protected native Object clone() throws CloneNotSupportedException this Clonazione Importante esempio di eccezione controllata è CloneNotSupportedException che può essere lanciata dal metodo nativo clone() della classe Object. La dichiarazione di clone() è la seguente: protected

Dettagli

Bank account. private double balance; 11/2/2011

Bank account. private double balance; 11/2/2011 Il Linguaggio Java Ereditarietà Bank account class BankAccount { public BankAccount() { balance = 0; } public void deposit(double amount) { balance += amount; } public void withdraw(double amount) { balance

Dettagli

Programmazione Orientata agli Oggetti in Linguaggio Java

Programmazione Orientata agli Oggetti in Linguaggio Java Programmazione Orientata agli Oggetti in Linguaggio Java Ereditarietà e Polimorfismo: Polimorfismo - d Regole Sintattiche e Semantiche versione 1.2 Questo lavoro è concesso in uso secondo i termini di

Dettagli

prompt> java SumAverage

prompt> java SumAverage I parametri del main sono inclusi in un vettore di String Parametri di ingresso /* sum and average command lines */ class SumAverage { public static void main (String args[]) { int sum = 0; float avg =

Dettagli

A. Lorenzi, A. Rizzi Java. Programmazione ad oggetti e applicazioni Android Istituto Italiano Edizioni Atlas

A. Lorenzi, A. Rizzi Java. Programmazione ad oggetti e applicazioni Android Istituto Italiano Edizioni Atlas Classi e oggetti A. Lorenzi, A. Rizzi Java. Programmazione ad oggetti e applicazioni Android Istituto Italiano Edizioni Atlas Oggetti La programmazione orientata agli oggetti, OOP (Object-Oriented Programming),

Dettagli

Inizializzare oggetti

Inizializzare oggetti Inizializzare oggetti Uso della Classe Software per TLC - AA 2008/2009 1 Costruttori e polimorfismo Uso della Classe Un codice migliore Software per TLC - AA 2008/2009 2 Costruttori ed Ereditarietà Output:

Dettagli

Implementazione Java di un ADT

Implementazione Java di un ADT Implementazione Java di un ADT Primo passo definire l'interfaccia (API) dell' ADT (l'api descrive i nomi dei metodi che l'adt supporta e come essi sono dichiarati e usati) Secondo passo scrivere il codice

Dettagli

16 - Ereditarietà, tipi e gerarchie

16 - Ereditarietà, tipi e gerarchie 16 - Ereditarietà, tipi e gerarchie 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

Dettagli

16 - Ereditarietà, tipi e gerarchie

16 - Ereditarietà, tipi e gerarchie 16 - Ereditarietà, tipi e gerarchie Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://pages.di.unipi.it/milazzo milazzo

Dettagli

17 - Ereditarietà, tipi e gerarchie

17 - Ereditarietà, tipi e gerarchie 17 - Ereditarietà, tipi e gerarchie 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

Dettagli

Informatica Ereditarietà Java. Ereditarietà

Informatica Ereditarietà Java. Ereditarietà Ereditarietà L'ereditarietà consente allo sviluppatore di riutilizzare il codice già scritto creando sottoclassi a partire da classi già definite. La sottoclasse eredita tutti gli attributi e tutti i metodi

Dettagli

Esempi al calcolatore su: 1) Costruttori ed ereditarietà 2) Subtyping e Polimorfismo

Esempi al calcolatore su: 1) Costruttori ed ereditarietà 2) Subtyping e Polimorfismo Esempi al calcolatore su: 1) Costruttori ed ereditarietà 2) Subtyping e Polimorfismo 1 Esempio 1: Costruttori ed ereditarietà Costruttori ed ereditarietà 2 Introduzione Java prevede due automatismi legati

Dettagli

Programmazione. Cognome... Nome... Matricola... Prova scritta del 11 luglio 2014

Programmazione. Cognome... Nome... Matricola... Prova scritta del 11 luglio 2014 Cognome................................ Nome................................... Matricola............................... Programmazione Prova scritta del 11 luglio 2014 TEMPO DISPONIBILE: 2 ore Negli esercizi

Dettagli

Gerarchia di classi Java 1

Gerarchia di classi Java 1 Specializzare un modello Gerarchia di classi Java Corso di laurea in Una classe modella un pezzo di realtà Una macchina, una moneta, un impiegato Spesso è necessario specializzare la versione originale

Dettagli

Programmazione orientata agli oggetti Subtyping e polimorfismo. Subtyping-polimorfismo

Programmazione orientata agli oggetti Subtyping e polimorfismo. Subtyping-polimorfismo Programmazione orientata agli oggetti Subtyping e polimorfismo 1 Subclassing e subtyping Fino ad ora abbiamo trattato l ereditarietà come strumento che consente il riuso flessibile di classi già esistenti

Dettagli

Polimorfismo. Subtyping-polimorfismo

Polimorfismo. Subtyping-polimorfismo Polimorfismo 23 Polimorfismo - Esempio Definiamo la classe Persona che gestisce i dati anagrafici di una persona (nome ed età per semplicità) La classe definisce un costruttore e il metodo print che stampa

Dettagli

Il paradigma OO e le Classi

Il paradigma OO e le Classi Oggetti e Classi (CAP 10) Alberto Garfagnini Università degli studi di Padova 1 Dicembre 2009 Il paradigma OO e le Classi La programmazione ad Oggetti () è una filosofia di programmazione che si basa sui

Dettagli

Classi astratte. Nella gerarchia delle classi, potrebbe essere utile prevedere un supertipo generale per le classi che si usano. Ad esempio: Figura

Classi astratte. Nella gerarchia delle classi, potrebbe essere utile prevedere un supertipo generale per le classi che si usano. Ad esempio: Figura Classi astratte Nella gerarchia delle classi, potrebbe essere utile prevedere un supertipo generale per le classi che si usano. Ad esempio: Figura Rettangolo getarea() Quadrato getarea() getarea() Cerchio

Dettagli

Programmazione. Cognome... Nome... Matricola... Prova scritta del 20 febbraio 2012

Programmazione. Cognome... Nome... Matricola... Prova scritta del 20 febbraio 2012 Cognome................................ Nome................................... Matricola............................... Programmazione Prova scritta del 20 febbraio 2012 TEMPO DISPONIBILE: 1 ora Negli

Dettagli

e il loro uso: Oggetti composti IL TEMA DELLA RIUSABILITÀ APPROCCI PER IL RIUTILIZZO:

e il loro uso: Oggetti composti IL TEMA DELLA RIUSABILITÀ APPROCCI PER IL RIUTILIZZO: APPROCCI PER IL RIUTILIZZO: ricopiare manualmente il codice della classe esistente e cambiare quel che va cambiato creare un oggetto composto che incapsuli il componente esistente... gli inoltri le operazioni

Dettagli

Esempio: Costruttori ed ereditarietà

Esempio: Costruttori ed ereditarietà Esempio: 1 Introduzione Java prevede due automatismi legati ai costruttori: Se una classe non ha costruttori viene creato automaticamente il costruttore di default (quello senza parametri) Se in un costruttore

Dettagli

PROGRAMMA DIDATTICO CONSUNTIVO

PROGRAMMA DIDATTICO CONSUNTIVO PROGRAMMA DIDATTICO CONSUNTIVO CLASSE 4Di Docenti Professoressa Elena Baraldi, Professor Nicola Tommasini Disciplina Informatica Unità di Lavoro 1: Programmazione orientata agli oggetti Periodo: settembre

Dettagli

public class Counter2 extends Counter { public void dec() { val--; }

public class Counter2 extends Counter { public void dec() { val--; } public class Main public class Counter2 extends Counter public void dec() val--; public class Counter public Counter() System.out.println("Counter : costruttore di default!"); val = 1; System.out.println("Counter

Dettagli

e il loro uso: esistente e cambiare quel che va cambiato specializzare (per ereditarietà) la classe Counter public class EsempioNuovo {

e il loro uso: esistente e cambiare quel che va cambiato specializzare (per ereditarietà) la classe Counter public class EsempioNuovo { APPROCCI PER IL RIUTILIZZO: ricopiare manualmente il codice della classe esistente e cambiare quel che va cambiato creare un oggetto composto che incapsuli il componente esistente... gli inoltri le operazioni

Dettagli

GESTIONE DEGLI ERRORI

GESTIONE DEGLI ERRORI GESTIONE DEGLI ERRORI Spesso vi sono istruzioni critiche, che in certi casi possono produrre errori L approccio classico consiste nell inserire controlli (if else..) per cercare di intercettare a priori

Dettagli

L ereditarieta` Riuso del software: Ereditarieta`, Composizione, Polimorfismo e Binding Dinamico Ereditarietà Ereditarietà

L ereditarieta` Riuso del software: Ereditarieta`, Composizione, Polimorfismo e Binding Dinamico Ereditarietà Ereditarietà L ereditarieta` Programmazione in Rete e Laboratorio Matteo Baldoni Dipartimento di Informatica Universita` degli Studi di Torino C.so Svizzera, 185 I-10149 Torino Riuso del software: Ereditarieta`, Composizione,

Dettagli

18 - Classi parzialmente definite: Classi Astratte e Interfacce

18 - Classi parzialmente definite: Classi Astratte e Interfacce 18 - Classi parzialmente definite: Classi Astratte e Interfacce Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://www.di.unipi.it/

Dettagli

17 - Classi parzialmente definite: Classi Astratte e Interfacce

17 - Classi parzialmente definite: Classi Astratte e Interfacce 17 - Classi parzialmente definite: Classi Astratte e Interfacce Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://www.di.unipi.it/

Dettagli

GESTIONE DEGLI ERRORI

GESTIONE DEGLI ERRORI GESTIONE DEGLI ERRORI Spesso vi sono istruzioni critiche, che in certi casi possono produrre errori L approccio classico consiste nell inserire controlli (if else..) per cercare di intercettare a priori

Dettagli

Gerarchie e polimorfismo: liste

Gerarchie e polimorfismo: liste Gerarchie e polimorfismo: liste 1 Generalizzare le liste di interi List lista di oggetti non modificabile vorremo poi definire un sottotipo versione ordinata 2 List classe astratta usate i sottotipi per

Dettagli

Ereditarietà. Una classe, detta superclasse, può essere specializzata definendo una sottoclasse che ne contenga casi particolari.

Ereditarietà. Una classe, detta superclasse, può essere specializzata definendo una sottoclasse che ne contenga casi particolari. Ereditarietà Per definire stato e comportamento di nuovi oggetti, è utile avere una base da cui partire In particolare, un nuovo oggetto potrebbe essere un caso particolare di una tipologia di oggetti

Dettagli

Programmazione orientata agli oggetti Subtyping e polimorfismo. Subtyping-polimorfismo

Programmazione orientata agli oggetti Subtyping e polimorfismo. Subtyping-polimorfismo Programmazione orientata agli oggetti Subtyping e polimorfismo 1 Subclassing e subtyping Fino ad ora abbiamo trattato l ereditarietà come strumento che consente il riuso flessibile di classi già esistenti

Dettagli

Programmazione orientata agli oggetti Subtyping e polimorfismo. Subtyping-polimorfismo

Programmazione orientata agli oggetti Subtyping e polimorfismo. Subtyping-polimorfismo Programmazione orientata agli oggetti Subtyping e polimorfismo 1 Subclassing e subtyping Fino ad ora abbiamo trattato l ereditarietà come strumento che consente il riuso flessibile di classi già esistenti

Dettagli

Programmazione ad Oggetti C++

Programmazione ad Oggetti C++ Programmazione ad Oggetti C++ A5160039 Gianluigi Ciocca A.A. 2007-2008 Programmazione ad Oggetti Richiami (1) Elementi Fondamentali Astrazione Attenzione non su : come fare cosa Attenzione su : chi può

Dettagli

Gestire le situazioni di errore

Gestire le situazioni di errore Gestire le situazioni di errore #include using namespace std; Classe VettoreDiInteri const int MAX = 10; class VettoreInteri { int v[max]; public: ; Gestire le situazioni di errore Ottenere

Dettagli

07 Ereditarietà. Mirko Viroli C.D.L. Ingegneria e Scienze Informatiche Alma Mater Studiorum Università di Bologna, Cesena

07 Ereditarietà. Mirko Viroli C.D.L. Ingegneria e Scienze Informatiche Alma Mater Studiorum Università di Bologna, Cesena 07 Ereditarietà Mirko Viroli mirko.viroli@unibo.it C.D.L. Ingegneria e Scienze Informatiche Alma Mater Studiorum Università di Bologna, Cesena a.a. 2015/2016 Mirko Viroli (Università di Bologna) OOP07:

Dettagli

Definizione di classi

Definizione di classi Corso di Programmazione e Metodi Numerici Ingegneria Aerospaziale BAER Domenico Daniele Bloisi Docenti Metodi Numerici prof. Vittoria Bruni vittoria.bruni@sbai.uniroma1.it Programmazione prof. Domenico

Dettagli

ereditarietà e polimorfismo

ereditarietà e polimorfismo ereditarietà e polimorfismo Java ereditarietà o l ereditarietà permette di definire nuove classi partendo da classi sviluppate in precedenza o la nuova classe viene definita esprimendo solamente le differenze

Dettagli

Il puntatore alla classe base e le funzioni virtuali

Il puntatore alla classe base e le funzioni virtuali Polimorfismo Indice Le funzioni virtuali e il puntatore alla classe base Le funzioni virtuali pure Classi astratte: interfaccia Commenti sugli strumenti del C++ e l OOD Il puntatore alla classe base e

Dettagli