Informatica e Laboratorio di Programmazione C++ Object Oriented Programming Alberto Ferrari
|
|
|
- Ornella Pala
- 7 anni fa
- Visualizzazioni
Transcript
1 Informatica e Laboratorio di Programmazione C++ Object Oriented Programming Alberto Ferrari
2 oggetti o in C++ la definizione della classe è separata dalla implementazione dei metodi o definizione fornita agli utenti o implementazione compilata in libreria o sorgenti organizzati in 3 file: o Ball.h definizione della classe o Ball.cpp implementazione dei metodi o main.cpp applicazione che usa la classe o ambiente di sviluppo: file new C++ Class Alberto Ferrari Informatica e Laboratorio di Programmazione
3 definizione Ball.h #ifndef BALL_H #define BALL_H class Ball { public: Ball(int x0, int y0); void move(); int get_x(); int get_y(); static const int ARENA_W = 320; static const int ARENA_H = 240; static const int W = 20; static const int H = 20; private: int x; int y; int dx; int dy; ; #endif // BALL_H Alberto Ferrari Informatica e Laboratorio di Programmazione
4 implementazione: Ball.cpp #include "Ball.h" Ball::Ball(int x0, int y0) { x = x0; y = y0; dx = 5; dy = 5; void Ball::move() { if (!(0 <= x + dx && x + dx <= ARENA_W - W)) dx = -dx; if (!(0 <= y + dy && y + dy <= ARENA_H - H)) dy = -dy; x += dx; y += dy; int Ball::get_x() { return x; int Ball::get_y() { return y;
5 applicazione: main.cpp #include <iostream> #include "Ball.h" using namespace std; int main() { Ball b1{40, 80; Ball b2{80, 40; for (auto i = 0; i < 25; ++i) { b1.move(); b2.move(); cout << b1.get_x() << ", " << b1.get_y() << endl; cout << b2.get_x() << ", " << b2.get_y() << endl << endl;
6 allocazione dinamica Ball b1{40, 80; Ball* b2 = new Ball{80, 40; // Ball* alias1 = &b1; // no new ball is created // Ball* alias2 = b2; // no new ball is created for (auto i = 0; i < 25; ++i) { b1.move(); b2->move(); cout << b1.get_x() << ", " << b1.get_y() << endl; cout << b2->get_x() << ", " << b2->get_y() << endl << endl; delete b2; no garbage collection: a new deve corrispondere delete
7 garbage collector o per garbage collection (letteralmente raccolta dei rifiuti) si intende una modalità automatica di gestione della memoria, mediante la quale un sistema operativo, o un compilatore e un modulo di run-time, liberano le porzioni di memoria che non dovranno più essere successivamente utilizzate dalle applicazioni Wikipedia
8 puntatori o ogni dato presente in memoria ha un indirizzo o una variabile puntatore contiene un indirizzo o operatore & per indirizzo di un dato o operatore * per accesso a dato puntato (dereferenziazione) char i = 56; // a byte char* p; // a ptr to some byte (uninitialized) p = &i; // now p points to i *p = *p + 1; // ++i p = nullptr; // ptr to nothing Alberto Ferrari Informatica e Laboratorio di Programmazione
9 OOP astrazione Alberto Ferrari Informatica e Laboratorio di Programmazione
10 esempio: fattoria parlante o classe base come interfaccia astratta o es. Animal o tutti fanno un verso (interfaccia) o ognuno lo fa diverso (polimorfismo) class Animal { public: virtual void say() = 0; ; Alberto Ferrari Informatica e Laboratorio di Programmazione
11 classi concrete class Dog : public Animal { string name_; public: Dog(string name) { name_ = name; void say() { cout << "I am " << name_ << " Dog. I say: WOOF!" << endl; ; class Cat : public Animal { string name_; public: Cat(string name) { name_ = name; void say() { cout << "I am " << name_ << " Cat. I say: MEOW!" << endl; ; Alberto Ferrari Informatica e Laboratorio di Programmazione
12 lista di puntatori a oggetti // a list of Animal objects auto d = new Dog("Danny"); auto c = new Cat("Candy"); auto p1 = new Pig("Peppa"); auto p2 = new Pig("George"); vector<animal*> animals = {d, c, p1, p2; for (auto a : animals) { a->say();
13 metodi virtuali puri o esempio: metodo move di Actor o virtual: il metodo può essere ridefinito nelle sottoclassi (polimorfo) o = 0: il metodo non è implementato qui (la classe è astratta) o polimorfismo C++ funziona solo con puntatori a oggetti class Actor { virtual void move() = 0; //... ;
14 Fifteen gioco astratto #ifndef BOARDGAME_H #define BOARDGAME_H #include <string> class BoardGame { public: virtual void play_at(int x, int y) = 0; virtual void flag_at(int x, int y) = 0; virtual int cols() = 0; virtual int rows() = 0; virtual std::string get_val(int x, int y) = 0; virtual bool finished() = 0; virtual std::string message() = 0; ; virtual ~BoardGame() { #endif // BOARDGAME_H Alberto Ferrari Informatica e Laboratorio di Programmazione
15 gioco a console void print_game(boardgame* game) { for (auto y = 0; y < game->rows(); ++y) { for (auto x = 0; x < game->cols(); ++x) { cout << setw(3) << game->get_val(x, y); cout << endl; void play_game(boardgame* game) { print_game(game); while (! game->finished()) { int x, y; cin >> x >> y; game->play_at(x, y); print_game(game); cout << game->message() << endl;
Laboratorio di Algoritmi e Strutture Dati
Realizzazione di Liste Laboratorio di Algoritmi e Strutture Dati Domenico Redavid [email protected] Materiale di base gentilmente concesso dal dott. Nicola Di Mauro Ricercatore presso l'univ. di Bari
La programmazione ad oggetti (OOP)
Oggetti e Classi (CAP 10) Alberto Garfagnini, Marco Mazzocco Università degli studi di Padova 30 Novembre 2011 La programmazione ad oggetti (OOP) È un approccio concettuale alla programmazione (indipendente
Informatica 1 Tipi e dichiarazioni in C++ C++ - Tipi e dichiarazioni 1
Informatica 1 Tipi e dichiarazioni in C++ C++ - Tipi e dichiarazioni 1 Cosa è il C++ E un linguaggio di programmazione derivato dal C Può essere usato per modificare il SO Unix e i suoi derivati (Linux)
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
Laboratorio di Informatica
Liste semplici (semplicemente linkate) Una lista semplice e costituita da nodi Laboratorio di Informatica 7. Strutture complesse di dati in C++ Ogni nodo e una struttura che contiene : Dati Un riferimento
Classe Squadra. #include <iostream> using namespace std;
Classe Squadra Si vuole scrivere un programma che gestisce la classifica di un campionato tra squadre di calcio, ognuna identificata dal proprio nome. Il programma deve essere in grado di assegnare un
Informatica e Laboratorio di Programmazione C++ stream Alberto Ferrari. Alberto Ferrari Informatica e Laboratorio di Programmazione
Informatica e Laboratorio di Programmazione C++ stream Alberto Ferrari Alberto Ferrari Informatica e Laboratorio di Programmazione stream o l input/output del C++ è basato sugli stream o gli stream sono
Algoritmo di ordinamento per sostituzione. Esempio : dato l array :
Algoritmo di ordinamento per sostituzione Per ottenere un ordinamento crescente con l algoritmo di ordinamento per Sostituzione si confronta l elemento nella prima posizione con gli elementi nelle posizioni
Sommario. Introduzione... xv. Giorno 1 Elementi base del linguaggio C
Sommario Introduzione... xv Organizzazione del volume... xv Argomenti...xvi Domande...xvi Verifiche...xvi Domande e risposte...xvi Esercizi...xvi Non è richiesta alcuna precedente esperienza di programmazione...
Laboratorio di Programmazione e Calcolo
UNIVERSITA DEGLI STUDI ROMA TRE DIPARTIMENTO DI FISICA E. AMALDI Laboratorio di Programmazione e Calcolo 6 crediti a cura di Severino Bussino Anno Accademico 2016-17 0) Struttura del Corso 1) Trattamento
ESERCIZI DI PROGRAMMAZIONE C/C++ per le classi seconde
ESERCIZI DI PROGRAMMAZIONE C/C++ per le classi seconde vers.0 in lavorazione Docente SAFFI FABIO Contenuti Struttura del file sorgente...2 Organizzazione della directory di lavoro...2 Esercizi sulle funzione
Programmazione ad oggetti
Programmazione ad oggetti OOP La programmazione orientata agli oggetti (Object Oriented Programming) ha l obiettivo di formalizzare gli oggetti del mondo reale e di costruire con questi un mondo virtuale.
Informatica! Appunti dal laboratorio 1!
Informatica Appunti dal laboratorio 1 Sistema Operativo Windows Vista, Windows 7, Mac OS X, Linux, Debian, Red Hat, etc etc Il sistema operativo è un programma che serve a gestire TUTTE le risorse presenti
Introduzione al C++ Corso di C++ INFN LNS 13 Dicembre Corrado Santoro
Introduzione al C++ Corso di C++ INFN LNS 13 Dicembre 2010 Corrado Santoro Concetto di Oggetto Proposto del 1966 nell'ambito dell'ai per rappresentare l' universo del discorso (ambiente di riferimento
Gestione dinamica della memoria
Programmazione M-Z Ingegneria e Scienze Informatiche - Cesena A.A. 2016-2017 Gestione dinamica della memoria Pietro Di Lena - [email protected] A pessimistic programmer sees the array as half empty.
Università degli Studi di Cassino Corso di Fondamenti di Informatica Puntatori. Anno Accademico 2010/2011 Francesco Tortorella
Corso di Informatica Puntatori Anno Accademico 2010/2011 Francesco Tortorella Variabili, registri ed indirizzi Abbiamo visto che la definizione di una variabile implica l allocazione (da parte del compilatore)
Programmazione modulare
Programmiamo in.. Programmazione modulare Un programma complesso si suddivide in più sottoprogrammi o funzioni. Un programma suddiviso in piccoli pezzi, è più semplice da gestire da aggiornare da correggere
Lezione 8: Stringhe ed array multidimensionali
Lezione 8: Stringhe ed array multidimensionali Vittorio Scarano Corso di Laurea in Informatica Università degli Studi di Salerno Struttura della lezione AVVISO: la lezione di laboratorio di 28/5 non si
Aritmetica dei puntatori
Aritmetica dei puntatori Marco Alberti Programmazione e Laboratorio, A.A. 2016-2017 Dipartimento di Matematica e Informatica - Università di Ferrara Ultima modifica: 7 dicembre 2016 sizeof L operatore
La classe std::vector della Standard Template Library del C++
La classe std::vector della Standard Template Library del C++ Alberto Garfagnini Università degli studi di Padova 23 Ottobre 2013 Programmazione generica in C++ : i Template I templates sono probabilmente
Gestione di stringhe. Le stringhe in C/C++
Alessio Bechini - Corso di - Gestione di stringhe Parte del materiale proposto è stato gentilmente fornito da G. Lipari Le stringhe in C/C++ In C e in C++ non esiste un vero e proprio tipo stringa. Una
Il linguaggio C. Puntatori e dintorni
Il linguaggio C Puntatori e dintorni 1 Puntatori : idea di base In C è possibile conoscere e denotare l indirizzo della cella di memoria in cui è memorizzata una variabile (il puntatore) es : int a = 50;
Ricerca binaria (o dicotomica) di un elemento in un vettore
Ricerca binaria (o dicotomica) di un elemento in un La ricerca binaria o dicotomica è utilizzata per ricercare i dati in un ORDNATO. L algoritmo di ricerca binaria, dopo ogni confronto, scarta metà degli
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),
Università degli Studi di Cassino Corso di Fondamenti di Informatica Tipi strutturati: Stringhe. Anno Accademico 2010/2011 Francesco Tortorella
Corso di Informatica Tipi strutturati: Stringhe Anno Accademico 2010/2011 Francesco Tortorella Stringhe di caratteri La stringa è il tipo strutturato con cui vengono rappresentati gruppi di caratteri quali
Le stringhe. Le stringhe
Informatica: C++ Gerboni Roberta Stringhe di caratteri (esempi di utilizzo dei vettori) Nel linguaggio C++ una stringa è semplicemente un vettore di caratteri Vettori di caratteri La stringa "hello" è
L AMBIENTE CODE BLOCKS E L IO
L AMBIENTE CODE BLOCKS E L IO Il primo programma in C++ #include using namespace std; main() { cout
