Az OO paradigma. Mitől OO egy program? Objektum Osztály Öröklődés



Hasonló dokumentumok
Az OO paradigma. Mitől OO egy program? Objektum Osztály Öröklődés

Visual C++ osztály készítése, adattagok, és metódusok, láthatóság, konstruktor, destruktor. Objektum létrehozása, használata, öröklés.

Széchenyi István Egyetem. Programozás III. Varjasi Norbert

JAVA PROGRAMOZÁS 2.ELŐADÁS

Programozás II. 3. gyakorlat Objektum Orientáltság C++-ban

Objektumorientált programozás C# nyelven

OOP. Alapelvek Elek Tibor

Bevezetés a Python programozási nyelvbe

Virtuális függvények (late binding)

Számítástechnika II. BMEKOKAA Előadás. Dr. Bécsi Tamás

Pelda öröklődésre: import java.io.*; import java.text.*; import java.util.*; import extra.*;

Java programozási nyelv 5. rész Osztályok III.

Programozás módszertan p.1/46

Osztályok. 4. gyakorlat

Java VI. Miskolci Egyetem Általános Informatikai Tanszék. Utolsó módosítás: Ficsor Lajos. Java VI.: Öröklődés JAVA6 / 1

Bevezetés a Programozásba II 8. előadás. Polimorfizmus Giachetta Roberto

Java programozási nyelv 4. rész Osztályok II.

Programozási nyelvek Java

Statikus adattagok. Statikus adattag inicializálása. Speciális adattagok és tagfüggvények. Általános Informatikai Tanszék

Programozás II. 2. gyakorlat Áttérés C-ről C++-ra

Öröklés és Polimorfizmus

Interfészek. PPT 2007/2008 tavasz.

OOP: Java 8.Gy: Abstract osztályok, interfészek

III. OOP (objektumok, osztályok)

Programozás. C++ osztályok. Fodor Attila. Pannon Egyetem Műszaki Informatikai Kar Villamosmérnöki és Információs Rendszerek Tanszék

Objektumelvű alkalmazások fejlesztése 6. gyakorlat. Öröklődés, polimorfizmus. Öröklődés Kódismétlődés objektum-orientált szerkezetben

Helyes-e az alábbi kódrészlet? int i = 1; i = i * 3 + 1; int j; j = i + 1; Nem. Igen. Hányféleképpen lehet Javaban megjegyzést írni?

Már megismert fogalmak áttekintése

Osztálytervezés és implementációs ajánlások

Programozás I. 5. gyakorlat. Szegedi Tudományegyetem Természettudományi és Informatikai Kar

Osztálytervezés és implementációs ajánlások

és az instanceof operátor

1. Öröklés Rétegelés Nyilvános öröklés - isa reláció Korlátozó öröklődés - has-a reláció

Objektumelvű programozás

Java VIII. Az interfacei. és az instanceof operátor. Az interfészről általában. Interfészek JAVA-ban. Krizsán Zoltán

Programozás. Objektum Orientált Programozás (OOP) Alapfogalmak. Fodor Attila

Számítástechnika II. BMEKOKAA Előadás. Dr. Bécsi Tamás

Objektumorientált programozás C# nyelven

Alkalmazott Modul III 6. előadás. Objektumorientált programozás: öröklődés és polimorfizmus

Osztály és objektum fogalma

Bevezetés a programozásba előadás: Öröklődés

OOP #1 (Bevezetés) v :39:00. Eszterházy Károly Főiskola Információtechnológia tsz. Hernyák Zoltán adj.

Programozás II. 4. Dr. Iványi Péter

Java VII. Polimorfizmus a Java nyelvben

Java V. Osztályszint. lyszintű ű tagok. Példányváltozó. Osztályváltozó. Általános Informatikai Tanszék Utolsó módosítás:

Elemi Alkalmazások Fejlesztése II.

C++ programozási nyelv Konstruktorok-destruktorok

Miután létrehoztuk, szeretnénk neki beszédesebb nevet adni. A név változtatásához a következőt kell tenni:

OOP alapok Egy OOP nyelvet három fontos dolog jellemez. egységbezárás ( encapsulation objektumoknak öröklés ( inheritance

Programozás BMEKOKAA146. Dr. Bécsi Tamás 7. előadás

Globális operátor overloading

Java VII. Polimorfizmus a Java nyelvben

Programozási technikák Pál László. Sapientia EMTE, Csíkszereda, 2009/2010

Objektum-orientált programozás

OBJEKTUM ORIENTÁLT PROGRAMOZÁS JAVA NYELVEN. vizsgatételek

Programozási alapismeretek 4.

1. Mi a fejállományok szerepe C és C++ nyelvben és hogyan használjuk őket? 2. Milyen alapvető változókat használhatunk a C és C++ nyelvben?

Objektumorientált szoftverfejlesztés alapjai

Alkalmazott modul: Programozás 11. előadás. Objektumorientált programozás: öröklődés

Programozás II gyakorlat. 6. Polimorfizmus

Adatstruktúrák, algoritmusok, objektumok

Programozási nyelvek Java

Programozás III KIINDULÁS. Különböző sportoló típusok vannak: futó, magasugró, focista, akik teljesítményét más-más módon határozzuk meg.

Dr. Pál László, Sapientia EMTE, Csíkszereda WEB PROGRAMOZÁS 2.ELŐADÁS. Objektumorientált programozás

Objektumok inicializálása

C# osztálydeníció. Krizsán Zoltán 1. .net C# technológiák tananyag objektum orientált programozás tananyag

Szoftvertechnológia 4. előadás. Objektumorientált tervezés: általánosítás. Giachetta Roberto. Eötvös Loránd Tudományegyetem Informatikai Kar

Programozás III. - NGB_IN001_3

Java VI. Egy kis kitérő: az UML. Osztály diagram. Általános Informatikai Tanszék Utolsó módosítás:

Programozási technológia

OOP #14 (referencia-elv)

OOP és UML Áttekintés

Programozás II. 6.Öröklés Dr. Iványi Péter

3. Osztályok II. Programozás II

0.2.1 Operátorok túlterhelése (műveletek definiálhatók felhaszn. típusokra) Kutya. Eb1. Eb2. Név (txt): Rex. Blöki. Német juhász 3

500. AA Megoldó Alfréd AA 500.

osztályok kapcsolata Származtatatás C++ Izsó Tamás március 19. Izsó Tamás Származtatatás/ 1

C++ programozási nyelv

Objektumorientált Programozás C++ ADATSZERKEZETEK ÉS ALGORITMUSOK 2. GYAKORLAT

Pénzügyi algoritmusok

Felhasználó által definiált adattípus

ISA szimulátor objektum-orientált modell (C++)

Osztályok. construct () destruct() $b=new Book(); $b=null; unset ($b); book.php: <?php class Book { private $isbn; public $title;

Bevezetés a Programozásba II 5. előadás. Objektumorientált programozás és tervezés

Programozás C++ -ban

Bevezetés a programozásba Előadás: A const

C++ programozási nyelv Struktúrák a C++ nyelvben

Programozás. C++ osztályok. Fodor Attila. Pannon Egyetem Műszaki Informatikai Kar Villamosmérnöki és Információs Rendszerek Tanszék

Programozás C++ -ban 2007/7

1. Template (sablon) 1.1. Függvénysablon Függvénysablon példányosítás Osztálysablon

A szemantikus elemzés helye. A szemantikus elemzés feladatai. A szemantikus elemzés feladatai. Deklarációk és láthatósági szabályok

Objektumorientált paradigma és programfejlesztés Bevezető

Interfészek. Programozás II. előadás. Szénási Sándor.

Bánsághi Anna 2014 Bánsághi Anna 1 of 33

Programozás II gyakorlat. 8. Operátor túlterhelés

Kivételkezelés, beágyazott osztályok. Nyolcadik gyakorlat

Smalltalk 3. Osztályok létrehozása. Készítette: Szabó Éva

Objektum orientált programozás Bevezetés

Bevezetés a programozásba Előadás: Tagfüggvények, osztály, objektum

Átírás:

2. előadás

Az OO paradigma Mitől OO egy program? Objektum Osztály Öröklődés 2

A valós világ modellezése Az ember a világ megértéséhez modelleket épít Modellezési alapelvek Absztrakció az a szemléletmód, amelynek segítségével a valós világot leegyszerűsítjük, úgy, hogy csak a lényegre, a cél elérése érdekében feltétlenül szükséges részekre összpontosítunk. Elvonatkoztatunk a számunkra pillanatnyilag nem fontos, közömbös információktól és kiemeljük az elengedhetetlen fontosságú részleteket. 3

A valós világ modellezése Megkülönböztetés Az objektumok a modellezendő valós világ egy-egy önálló egységét jelölik. Az objektumokat a számunkra lényeges tulajdonságaik, viselkedési módjuk alapján megkülönböztetjük. 4

A valós világ modellezése Osztályozás Az objektumokat kategóriákba, osztályokba soroljuk, oly módon, hogy a hasonló tulajdonságokkal rendelkező objektumok egy osztályba, a különböző vagy eltérő tulajdonságokkal rendelkező objektumok pedig külön osztályokba kerülnek. Az objektum-osztályok hordozzák a hozzájuk tartozó objektumok jellemzőit, objektumok mintáinak tekinthetők. 5

A valós világ modellezése Osztályozás Bodri Kutya Csonti

A valós világ modellezése Osztályozás Simba Oroszlán Leó

A valós világ modellezése Általánosítás, specializálás Az objektumok között állandóan hasonlóságokat vagy különbségeket keresünk, hogy ezáltal bővebb vagy szűkebb kategóriákba, osztályokba soroljuk őket. 8

A valós világ modellezése Élőlény Ember Állat Növény Emlős Madár Nyitvatermő Zárvatermő

Objektum Belső állapota van, ebben információt tárol, (adattagokkal valósítjuk meg) kérésre feladatokat hajt végre metódusok - melyek hatására állapota megváltozhat üzeneteken keresztül lehet megszólítani ezzel kommunikál más objektumokkal Minden objektum egyértelműen azonosítható 10

Ablak objektum Üzenetek setvisible(true) setlocation(40,8) setsize(20,16) settitle("ablak") aframe (20,16) (100,80) "Ablak" true Adattagok (attribútumok) location(x,y) size(width,height) title visible 11

Osztály, példány Osztály (class) Olyan objektumminta vagy típus, mely alapján példányokat (objektumokat) hozhatunk létre Példány (instance) Minden objektum születésétől kezdve egy osztályhoz tartozik 12

Frame osztály és példányai Frame location(x,y) size(x,y) title visible setvisible(visible) setlocation(x,y) setsize(width,height) settitle(title) 13

Osztály és példány az UML-ben Osztály neve Adatok/ Attribútumok/ Információk/ Változók/ Mezők Üzenetek/ Műveletek/ Metódusok/ Operációk/ Rutinok Frame location(x,y) size(width,height) title: String visible: boolean setvisible(visible) setlocation(x,y) setsize(width,height) settitle(title) aframe:frame location=(10,6) size=(20,12) title="ablak" visible=true Példány (Objektum) Osztály Példány neve és osztálya Példány adatai belső állapota

Osztály és példány a C++-ban class Employee { } string first_name, family_name; short department; // az adattagok alapértelmezésben privát hozzáférésűek! public: void print() const { // } string name() const { // } Employee empl; Employee * emplp; 15

Objektum létrehozása, inicializálása Objektum életciklusa: megszületik, él, meghal Az objektumot létre kell hozni és inicializálni kell! Objektum inicializálása konstruktor (constructor) végzi adatok kezdőértékadása objektum működéséhez szükséges tevékenységek végrehajtása típusinvariáns beállítása 16

Objektum létrehozása, inicializálása Ember pozíció(x:number,y:number) irányszög:number Ember(x:number,y:number) megy(táv:number) elmegy(x:number,y:number) fordul(szög:number) Kati:Ember pozíció=(100,50) irányszög=0 Kati = new Ember(100,50)

Objektum létrehozása, inicializálása C++-ban class Employee { string first_name, family_name; short department; // public: Employee (const string& f, const string& n, short d): first_name(f), family_name(n), department(d){} // } 18

C++ konstruktorok: nincs objektum konstruktor nélkül, ha kell, implicit hívódnak neve megegyezik az osztály nevével ha már megadtunk egy konstruktort, akkor default konstruktor nem definiálódik a default konstruktor meghívja az attribútumok konstruktorát, de a beépített típusokat nem inicializálja (konzisztensen a C-vel) a konstruktornak nem lehet visszatérési értéke a destruktort is explicite lehet hívni a delete operátorral, vagy implicit hívódik a blokkból való kilépéskor fordított sorrendben

Objektum műveletei Export műveletek amelyeket más objektumok hívhatnak pl. verem: push, pop, top stb. Import műveletek amelyeket az objektum igényel ahhoz, hogy az export szolgáltatásait nyújtani tudja pl. verem, ha fix méretű (vektoros) reprezentáció: vektorműveletek 20

Objektum műveletei Export műveletek csoportosítása: Létrehozó (konstruktor) az objektum létrehozására, felépítésére pl. veremnél: create: Verem Állapot megváltoztató pl. veremnél: pop: Verem Verem push: Verem x Elem Verem 21

Objektum műveletei Export műveletek csoportosítása: Szelektor kiemeli az objektum bizonyos részét pl. vektor adott indexű elemét access: Vektor x Index Elem Kiértékelő objektum jellemzőit lekérdező műveletek (size, has, stb.) Iterátor - bejáráshoz 22

Objektum műveletei Export műveletek csoportosítása: konstruktor objektum kiértékelő, szelektor iterátor állapot megváltoztató 23

Kliens üzen a szervernek kliens üzenet (kérelem) szerver A feladatot elvégeztető objektum Kívülről elérhető metódus hívása A feladatot elvégző objektum

Kliens üzen a szervernek Kliens: aktív objektum, másik objektumon végez műveleteket, de rajta nem végeznek. Nincs export felülete. Pl. óra meghatározott időközönként művelet egy regiszteren. Szerver: passzív objektum, csak export felülete van. Másoktól érkező üzenetekre vár, mások szolgáltatását nem igényli. Nincs import felülete. Ágens: általános objektum, van export és import felülete. 25

Osztály, példány Minden objektum? Akkor az osztályok is Lehet belső állapotuk, Küldhetünk üzeneteket neki Minek az objektuma? metaosztály singleton objektum És a metaosztály? 26

Osztály, példány Osztálydefiníció: Példányváltozó Példányonként helyet foglaló változó Példánymetódus Példányokon dolgozó metódus Osztályváltozó Osztályonként helyet foglaló változó Osztálymetódus Osztályokon dolgozó metódus 27

Osztálydefiníció Osztálymetódusok metódus1 omet1 Példánymetódusok a és b osztálya metódus2. metódusi. metódusn változó1: típus1 változó2: típus2. változóm: típusm omet2 ometj ov1: tip1 ov2: tip2. a.metódusi (üzenet) Példányváltozók Osztályváltozók (objektumok állapotleírója) (osztályok a (példány) b (példány) állapotleírója) változó1=aérték1 változó1=bérték1 változó2=aérték2. változó2=bérték2. változóm=aértékm változóm=bértékm

Osztályváltozó, osztálymetódus C++-ban class Employee { string first_name, family_name; short department; static int num_emp; // }; int Employee::num_emp(0); Az osztályon kívül definiálni kell! 29

Osztályváltozó, osztálymetódus C++-ban az osztályon belül elérhető, pl.: class Employee { string first_name, family_name; short department; static int num_emp; public: Employee (const string& f, const string& n, short d): first_name(f), family_name(n), department(d){num_emp++;} }; 30

Osztályváltozó, osztálymetódus C++-ban kívülről hozzáférni csak public metódussal lehet: class Employee { string first_name, family_name; short department; static int num_emp; public: static int get_num_emp(){ return num_emp;} static void print_num_emp(){ cout << "Az objektumok szama:" << num_emp << '\n'; }; 31

Osztályváltozó, osztálymetódus C++-ban kívülről hozzáférni csak public metódussal lehet: int main() } { Employee emp ("Kati","Fekete",3); emp.print_num_emp(); // vagy: Employee::print_num_emp(); 32

Osztályváltozó, osztálymetódus C++-ban class Datum{ int nap, ho, ev; static Datum alapert_datum; public: Datum(int nn=0, int hh=0, int ee=0); //... static void beallit_alapert(int,int,int); } Mire jó? Pl., ha paraméter nélküli konstruktor hívás történik, akkor az alapert_datum értéket kapja meg az új objektum. Az előző konstruktor helyett: Datum::Datum(int nn, int hh, int ee){ nap = nn? nn : alapert_datum.nap; ho = hh? hh : alapert_datum.ho; ev = ee? ee : alapert_datum.ev; }

Osztályváltozó, osztálymetódus C++-ban void Datum::beallit_alapert(int n, int h, int e){ //a statikus adattag értékének megváltoztatása Datum::alapert_datum = Datum(n,h,e); } definiálni kell, mielőtt használjuk!

Autó pozíció(x:number, y:number) irányszög: number sebesség: number maxsebesség: number=100 Autó(x,y,sebesség) megy(táv) elmegy(x,y) fordul(szög) setmaxsebesség(sebesség) bor144:autó pozíció=(5,93) irányszög=0 sebesség=85 bit079:autó pozíció=(28,8) irányszög=0 sebesség=50 Autó(5,93,85) megy(60) fordul(45) setmaxsebesség(50) Autó(28,8,50) megy(10) elmegy(25,10) megy(60) fordul(45) setmaxsebesség(100)

A this Ha egy osztályból több objektumot példányosítunk, honnan tudjuk, hogy éppen melyik objektum hívta meg a megfelelő metódust, és a metódus melyik objektum adataival fog dolgozni? Szükségünk van egy olyan mutatóra, amely mindig a metódust meghívó objektumpéldányra mutat. Ezt szolgálja a this paraméter. Ez metódushíváskor egyértelműen rámutat azokra az adatokra, amelyekkel a metódusnak dolgoznia kell. Ez azt is jelenti, hogy ha az objektum saját magának akar üzenetet küldeni, akkor a this.üzenet(paraméterek) formát kell, hogy használja, vagyis a metódustörzsekben az adott példányra mindig a this segítségével hivatkozhatunk. (Ez számos nyelvben alapértelmezett.) 36

OOP elvárások Bezárás (encapsulation) adatok és metódusok összezárása egybezárás, egységbezárás - osztály (class) Információ elrejtése (information hiding) az objektum belügyeit csak az interfészen keresztül lehet megközelíteni (láthatóságok!) Kód újrafelhasználása (code reuse) megírt kód felhasználása példány létrehozásával vagy osztály továbbfejlesztésével 37

Információ elrejtése Implementáció Interfész metódus 1 metódus 2 metódus 3... Adatok metódus N

Láthatóság Objektum védelme Osztály +publikusadat #védettadat -privátadat +publikusmetódus #védettmetódus -privátmetódus objektum :Osztály objektum.publikusadat objektum.publikusmetódus objektum.védettadat objektum.védettmetódus objektum.privátadat objektum.privátmetódus

Osztály védelme Osztály +publikusadat #védettadat -privátadat +publikusmetódus #védettmetódus -privátmetódus UtódOsztály egymetódus Hivatkozások a metódusban: publikusadat védettadat privátadat publikusmetódus védettmetódus privátmetódus

C++ az adattagok és metódusok elrejtése megoldott a láthatóság minősítője lehet: - public - protected - private public - a külső felhasználók elérik protected csak a leszármazottak érhetik el private csak az adott osztály és barátai számára elérhető alapértelmezés az osztályoknál

OO program Egy objektumorientált program egymással kommunikáló objektumok összessége, melyben minden objektumnak megvan a feladatköre. fut vezérlő objektum üzenet3 objektum3 üzenet1 objektum1 üzenet2 üzenet1 objektum2

Öröklődés Az alapgondolat: a gyerekek öröklik őseik metódusait és változóit. Az örököl terminus azt jelenti, hogy az ősosztály minden metódusa és adattagja a gyerekosztálynak is metódusa és adattagja lesz. A gyerek minden új művelete vagy adattagja egyszerűen hozzáadódik az örökölt metódusokhoz és adattagokhoz. Minden metódus, amit átdefiniálunk a gyerekben, a hierarchiában felülbírálja az örökölt metódust. 43

Öröklődés Rovarok tulajdonságok IS-A reláció üzenetek Ős osztály Bogarak új_tulajdonságok felüldeft_üzenetek új_üzenetek Utód osztály 44

Öröklődés Dialog location(x,y) size(width,height) setlocation() setsize() 2 Button Ős osztály FileDialog file:string getfile():string setfile(file:string) Utód osztály 45

Ki mire képes? Ember pozíció IQ megy() tanul() beszél() Gergő Zsolt Bea Hallgató osztályzat tanul() Tanár elérhetőség tananyag tanít() beszél() János

Utód adatai, küldhető üzenetek a b m1 m2 Ős o1: Ős a, b Küldhető üzenetek m1 m2 Mi hajtódik végre? Ős.m1 Ős.m2 c d m1 m3 Utód o2: Utód a, b, c, d m1 m2 m3 Utód.m1 Ős.m2 Utód.m3

C++ példa az öröklődésre: class Employee { string first_name, family_name; short department; static int num_emp; public: Employee (const string& f, const string& n, short d): first_name(f), family_name(n), department(d) {num_emp++;} void print() const { cout << "A vezeteknev:" << name() << '\n ; } string name() const { return family_name; } 48

C++ példa az öröklődésre: static int get_num_emp(){ return num_emp; } static void print_num_emp(){ cout << "Az objektumok szama:" << num_emp << '\n'; // }; } 49

class Manager: public Employee { Employee* group; short level; public: Manager (const string& f, const string& n, short d, short lvl): Employee(f,n,d), level(lvl){}; void print () const { cout << "A keresett nev:" << name() << '\n'; cout << "A szint:" << level << '\n'; } }; 50

int main() { Employee emp ("Kati","Fekete",3); Manager m("jozsef", "Kovacs", 3,2); emp.print (); } m.print(); 51

Polimorfizmus Polimorfizmus (többalakúság): az a jelenség, hogy egy változó nem csak egyfajta típusú objektumra hivatkozhat. Statikus típus: a deklaráció során kapja. Dinamikus típus: run-time éppen milyen típusú objektumra hivatkozik = a statikus típus, vagy annak leszármazottja. Aki Manager, az egy (is-a) Employee is. A Háromszög az egy Alakzat. 52

C++: Employee emp ("Kati","Fekete",3); Manager m("jozsef", "Kovacs", 3,2); emp = m; megengedett emp.print(); m. print(); mi történik? 53

Hogy lenne jó? a aobj A b bobj B a:=b 54

Altípusos polimorfizmus Employee* empp=new Employee ("Istvan", "Nagy",5); Manager* mp=new Manager("Laszlo", "Hajto", 2, 3); empp = mp; 55

Altípusos polimorfizmus Shape *s; s = new Triangle (...);... s = new Rectangle (...);... Ha B (pl. Triangle, Rectangle) altípusa az A (pl. Shape) típusnak, akkor B objektumainak referenciái értékül adhatók az A típus referenciáinak. 56

Shape *a; Triangle* h= new Triangle (...); Rectangle *t= new Rectangle (...); a = h; a->draw(); a = t; a->draw(); Melyik draw()? 57

Employee* empp=new Employee ("Istvan", "Nagy",5); Manager* mp=new Manager("Laszlo", "Hajto",2,3); empp = mp; empp->print(); Melyik print? 58

Dinamikus összekapcsolás Run-time fogalom. Az a jelenség, hogy a változó éppen aktuális dinamikus típusának megfelelő metódus implementáció hajtódik végre. A háromszög kirajzolása, a manager kinyomtatása. 59

Dinamikus összekapcsolás (2) A metódus m 1 ; metódus m 2 ; b: B B metódus m 2 ; 60

Dinamikus összekapcsolás C++-ban: class Employee { public: }. virtual void print() const { cout << "A vezeteknev:" << name() << '\n';// } 61

Mi az objektumorientált programozás? A programozó definiálhat altípus kapcsolatokat A típusszabályok megengedik, hogy az altípus használható legyen a szupertípus helyén (altípusos polimorfizmus) Típus-vezérelt metódus elérés (dinamikus kötés) Implementáció megosztása (öröklődés) 62

Típus-vezérelt metódus elérés s: Shape := new Triangle (3, 4, 5); s.draw(); Statikus elérés: A Shape draw metódusát hívja Dinamikus elérés: A Triangle draw metódusát hívja 63

Elérési döntések C++ Az őstípus virtual-nak deklarálja a metódust, amire megengedi a felüldefiniálást más programozási nyelveknél ez másképp lehet. 64

C++ példa (folyt.) egy leszármazott lehet ős is class Employee { }; class Manager : public Employee { }; class Director: public Manager { }; Az osztályhierarchia lehet fa, de lehet általánosabb gráf is: class Temporary { }; class Secretary: public Employee { }; class Tsec: public Temporary, public Secretary{ }; class Consultant: public Temporary, public Manager { }; 65

Temporary Employee Secretary Manager Tsec Director Consultant 66

Implementáció újrahasznosítás: alosztályképzés Használd egy típus implementációjátegy másik típus implementálására! Gyakran használjuk az őstípus implementációját az altípus implementálására A gyakran használt OO programozási nyelvek keverik az altípus és alosztály fogalmakat: C++ - implementációs öröklés altípus nélkül: private, protected öröklés 67

Egy típus- és osztályhierarchia Shape Quadrangle Triangle Equilateral Parallelogram Rectangle Rhombus EquilateralTriangle Square 68

Adjunk hozzá egy attribútumot! Az alakzatoknak legyen színe color és egy set_color metódusa A. Változtassuk meg a Shape, Quadrangle, Parallelogram, Triangle, Equilateral, EquilateralTriangle, Rhombus, Rectangle, Square stb. típusokat B. Változtassuk meg a Shape-t, a többiek öröklik az új attribútumot és metódust automatikusan 69

Adjuk hozzá az is_equilateral-t! bool Shape::is_equilateral () { return false; } bool Equilateral::is_equilateral () { } return true; 70

Egy Rhombus egyenlőoldalú? Shape is_equilateral () { return false; } Quadrangle Parallelogram Rhombus is_equilateral? Equilateral is_equilateral () { return true; } A többszörös öröklődésnek lehetnek problémái! 71

Kontra/Ko-Variancia Sportoló Síelő szobatárs(síelő) Hogyan tudja Síelő_Lány felüldefiniálni szobatárs-at? Kovariancia esetén: szobatárs (Síelő_Lány) / szobatárs (Síelő_Fiú) Kontravariancia esetén: szobatárs (Sportoló) Novariancia esetén: szobatárs (Síelő) Síelő_Fiú Síelő_Lány Probléma (kovariáns esetben): s: Sielo; g: Sielo_Lany; b: Sielo_Fiu; s := g;... s. szobatárs (b);

Mit tesz a C++? Lehet bevezetni kovariáns metódusokat az altípusban, de ezek túlterhelik az eredeti metódust, nem átdefiniálják! Példa: class sielo { public: }; virtual void szobatars(sielo * s){ cout<<"\n sielo szobatarsa sielo \n"; }; 73

class sielo_lany : public sielo { }; public: virtual void szobatars (sielo_lany *g){ cout<<"\n sielo_lany szobatarsa lany "; }; // túlterheli! virtual void szobatars (sielo *g){ cout<<"\n szobatars sielo_lanyban ; }; // átdefiniálja! class sielo_fiu : public sielo { //hasonlóan }

void main(){ sielo *s; sielo_lany *g; sielo_fiu *b; g= new sielo_lany; s = g; s->szobatars (b); // szobatars sielo_lanyban g->szobatars (b); // szobatars sielo_lanyban g->szobatars (g); // sielo_lany szobatarsa lany s->szobatars (g); // szobatars sielo_lanyban (!) } 75

Többszörös öröklődés Egy osztálynak egynél több közvetlen őse lehet Problémák: Adattagok hányszor? Melyik metódus? 76

A többszörös öröklődés problémái: class A{ int a; public: virtual void f (); }; class B : public A { public: void f ();}; class C : public A{ public: void f ();}; átdefiniál class D : public B, public C { }; átdefiniál

A többszörös öröklődés problémái: 1. Ha egy D-beli f -re (felüldefiniáltuk B-ben és/vagy C- ben) hivatkozunk, akkor az melyiket jelentse? (A v. B v. C) 2. Az a attribútum hány példányban jelenjen meg D-ben? A két kérdés lényegében ugyanazt a problémát veti fel: ha kétértelműség van, hogyan válasszunk? 78

Megoldási variációk: A legtöbb esetben az ilyen kódot nem lehet lefordítani, a fordító, vagy a futtató környezet kétértelműségre (ambiguous) hivatkozva hibajelzéssel leáll. Az ősosztály mondja meg, hogy mit szeretne tenni ilyen esetben. A származtatott osztály mondja meg, hogy melyiket szeretné használni. 79

C++ megoldás : D d;. d.f(); #error C2385: 'D::f' is ambiguous vagy: class D : public B, public C { public: using C::f; }; vagy: A a B és C virtuális bázisosztálya kell legyen a t (minden adattagot) csak egyszer örökli

C++ - többszörös öröklődés class Animal { public: virtual void eat(); }; class Mammal : public Animal { public: virtual Color gethaircolor(); }; class WingedAnimal : public Animal { public: virtual void flap(); }; // A bat is a winged mammal class Bat : public Mammal, public WingedAnimal { }; Bat bat; Hogyan eszik??

C++ - többszörös öröklődés class Mammal : public virtual Animal { public: virtual Color gethaircolor(); }; class WingedAnimal : public virtual Animal { public: virtual void flap(); }; // A bat is still a winged mammal class Bat : public Mammal, public WingedAnimal { };

Absztrakt osztály class Alakzat{ public: } virtual void kirajzol()=0; virtual bool zart()=0; 83

Absztrakt osztály Tervezés eszköze Egy felső szinten összefogja a közös tulajdonságokat A metódusok között van olyan, aminek csak specifikációja van, törzse nincs Nem hozható létre példánya. A leszármazott teszi konkréttá. 84

C++ class Sikidom { protected: int szelesseg, magassag; public: virtual int terulet()=0; void beallit_ertekek(int a, int b) {szelesseg = a; magassag = b;} }; class Teglalap: public Sikidom{ public: int terulet() {return (szelesseg * magassag);} }; class Haromszog: public Sikidom{ public: int terulet() {return (szelesseg * magassag /2);} };

C++ Nem lehet: Sikidom a; Lehet: Teglalap t; Haromszog h; /*...*/ Sikidom* a2 = &t; Sikidom* a3 = &h; a2->terulet(); //Teglalap::terulet() a3->terulet(); //Haromszog::terulet()

C++ Megvalósítás: Teglalap t; vptr szelesseg magassag Teglalap osztály virtuális metódustáblája &Teglalap::terulet &Teglalap:: beallit_ertekek

C++ public öröklődés: private protected public private protected public ős leszármazott

C++ private öröklődés: private protected public private protected public ős leszármazott

C++ protected öröklődés: private protected public private protected public ős leszármazott

C++ Mit örököl a leszármazott? Adattagokat Metódusokat Mit nem örököl a leszármazott? Ősosztály konstruktorait, destruktorát Ősosztály értékadás operátorát Ősosztály barátait

C++ Mit vezethet be a leszármazott osztály? Új adattagokat Új metódusokat Felüldefiniálhat már meglévőket Új konstruktorokat és destruktort Új barátokat

C++ egy általános metódus deklarációja a következőket jelenti: 1. a metódus elérheti a privát mezőket is 2. az osztály scope-ját használja 3. a metódus egy konkrét objektumra hívódik meg, ezért birtokolja a this pointert statikus metódus csak az 1, 2 - vel rendelkezik, ha egy függvényt friend-nek deklarálunk, akkor csak az 1. jogunk lesz (friend mechanizmus)

friend példa: typedef double Angle; class Complex { public: Complex(double r=0, double i=0){ R = r; I = i;} Complex operator =(Complex z){r = z.r; I = z.i; return *this; } Complex operator +(Complex z) {return Complex(R+z.R,I+z.I);} Complex operator +(double x) { return Complex(R+x,I);} Complex operator *(Complex); Complex operator *(double); Complex operator -(Complex); Complex operator -(double); Complex operator /(Complex); Complex operator /(double); double Re(); double Im(); double Abs(); Angle private: double R; double I; }; Phi();

C++ Complex operator + (double x, Complex z){ return z+x;} Vagy: osztály belsejébe: friend Complex operator+(double, Complex); Complex operator+(double p1, Complex p2) { Complex temp; temp.r = p1+p2.r; temp.i = p2.i; return (temp); }

C++ Még egy (tipikus) friend példa: class Point { friend ostream &operator<<( ostream &, const Point &); public: Point( int = 0, int = 0 ); // default constructor void setpoint( int, int ); // set coordinates int getx() const { return x; } // get x coordinate int gety() const { return y; } // get y coordinate protected: // accessible by derived classes int x, y; // x and y coordinates of the Point }; // end class Point