Szoftverprototípus készítése. Szoftverprototípus készítése. Szoftverprototípus készítése 2011.10.23.



Hasonló dokumentumok
Objektumorientált felbontás

Szoftverprototípus készítése

Bánsághi Anna 1 of 67

Előzmények

A SZOFTVERTECHNOLÓGIA ALAPJAI

Ismeretanyag Záróvizsgára való felkészüléshez

Az objektumorientált megközelítés elınye: Hátránya:

Rendszertervezés 2. IR elemzés Dr. Szepesné Stiftinger, Mária

Tartalom Kontextus modellek Viselkedési modellek Adat-modellek Objektum-modellek CASE munkapadok (workbench)

Bánsághi Anna Bánsághi Anna 1 of 54

A szerelés olyan művelet, amely során az alkatrészeket illetve a szerelési részegységeket további egységekké, gyártmánnyá kapcsoljuk össze.

Adatstruktúrák, algoritmusok, objektumok

A prototípus gyors, iteratív fejlesztése azért nagyon fontos, mert a költségek így ellenırizhetık.

Informatika szigorlati témakörök gazdasági informatika egyetemi képzés hallgatói részére

A hierarchikus adatbázis struktúra jellemzői

Szkeleton tervezése. 100 Generalis faliora. Csapattagok: Konzulens: Szabó András március 21.

Book Template Title. Author Last Name, Author First Name

2.1.A SZOFTVERFEJLESZTÉS STRUKTÚRÁJA

Informatika szigorlati témakörök gazdasági informatika egyetemi képzés hallgatói részére

Objektum Orientált Szoftverfejlesztés (jegyzet)

Programozás 1. 2.gyakorlat

7. Verifikáci. ció. Ennek része a hagyományos értelemben vett szoftvertesztelés is. A szoftver verifikálásának,

!!" KÉSZÍTK: ERDÉLYI LAJOS KOLLÁR NÁNDOR WD6OGW BUK8Y7

2. fejezet Hálózati szoftver

Bevezetés. Novell Netware 4.XX hálózati nyomtatók kezelése

MVC Java EE Java EE Kliensek JavaBeanek Java EE komponensek Web-alkalmazások Fejlesztői környezet. Java Web technológiák

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

WebSphere Adapters. 6. változat 2. alváltozat. WebSphere Adapter for SAP Software felhasználói kézikönyv 6. változat 2. kiadás

DSI működésre. tervezve. Hogyan fog kinézni a jövő informatikai infrastruktúrája? Egész szoftverrendszerek egy

axióma alapú automatizált teszteléssel

SZÁMVITELI POLITIKA SZABÁLYZATA

OBJEKTUMORIENTÁLT TERVEZÉS ESETTANULMÁNYOK. 2.1 A feladat

Operációs rendszerek. A Windows NT felépítése

3.1. Alapelvek. Miskolci Egyetem, Gyártástudományi Intézet, Prof. Dr. Dudás Illés

Adatbázisok I Adatmodellek komponensei. Adatbázis modellek típusai. Adatbázisrendszer-specifikus tervezés

TERMÉKTERVEZÉS PANDUR BÉLA TERMÉKTERVEZÉS

VÁLLALATI INFORMÁCIÓS RENDSZEREK, INTERNETES TECHNIKÁK

Követelmények a megbízható működés terén. Információbiztonsági osztályozás a megbízható működés szempontjából. T - T üz T

CNC technika. segédlet a CNC tantárgy oktatásához. Készítette: Paróczai János

Az élet szép, környezetünk tele van fákkal, virágokkal, repdeső madarakkal, vidáman futkározó állatokkal.

Tervezet A BIZOTTSÁG HATÁROZATA (...) a személyi számítógépek uniós ökocímkéjének odaítélésére vonatkozó ökológiai kritériumok megállapításáról

MŰANYAGOK FELDOLGOZÁSA

Termelési logisztikai rendszerek tervezése-fejlesztése

Elektronikus közhiteles nyilvántartások Megvalósítási tanulmány

4. Programozási nyelvek osztályozása. Amatőr és professzionális

Rendszerterv. 1. Funkcionális terv Feladat leírása:

A szoftverfolyamat és s a tesztelés

Komponens modellek. 3. Előadás (első fele)

Első Magyarországi Szoftvertesztelő Verseny Döntő feladatsor

FPGA áramkörök alkalmazásainak vizsgálata

IBM WebSphere Adapters 7. változat 5. alváltozat. IBM WebSphere Adapter for Oracle E-Business Suite felhasználói kézikönyv 7. változat 5.

SZAKDOLGOZAT. Titkó Szabolcs. Debrecen 2009.

Algoritmusok. Hogyan csináljam?

Többrétegű műszaki nyilvántartás. NETinv

Programozás III CSOMAGOK. Az összetartozó osztályok és interfészek egy csomagba (package) kerülnek.

Szervlet-JSP együttműködés

Bevezetés a C++ programozási nyelvbe

MILYEN A JÓ PROJEKTMENEDZSMENT

A stabil üzemű berendezések tápfeszültségét a hálózati feszültségből a hálózati tápegység állítja elő (1.ábra).

(11) Lajstromszám: E (13) T2 EURÓPAI SZABADALOM SZÖVEGÉNEK FORDÍTÁSA

Welcome3 Bele pteto rendszer

Termék- és márkastratégiai döntéseket támogató eszközök

Zárójelentés. Az autonóm mobil eszközök felhasználási területei, irányítási módszerek

A müncheni biohulladék-erjesztő teljesítményének növelése az előkezelő és víztisztító fokozatok módosításával

Nagy adattömbökkel végzett FORRÓ TI BOR tudományos számítások lehetőségei. kisszámítógépes rendszerekben. Kutató Intézet

SZÁMOLÁSTECHNIKAI ISMERETEK

Statisztikai Módszertani Füzetek, 51. A munkaerő-piaci politikák (LMP) adatbázisa (módszertan)

PÉCSI TUDOMÁNYEGYETEM

E-LEARNING ALAPÚ TÁVOKTATÁS A SZÉCHENYI ISTVÁN EGYETEMEN

Számítógépes grafika

ECP. Site Administration System. Felhasználói kézikönyv. v (1. kiadás a és újabb verziójú ECP SAS rendszerekhez)

TERMÉK FEJLESZTÉS PANDUR BÉLA TERMÉK TERVEZÉSE

Minőség- és környezetközpontú irányítási rendszer kézikönyve

MŰANYAGOK ALKALMAZÁSA

Magyarország működőtőke vonzása a nemzetközi tőkeáramlás folyamatában

DIPLOMAMUNKA KOVÁCS BALÁZS DEBRECEN

Corel PHOTO-PAINT X5 Maszkolástól nyomtatásig

Elektronikus dokumentumtárolási (EDT) szolgáltatás

ÁLTALÁNOS JELLEGŰ ELŐÍRÁSOK. A hitelesítési folyamat résztvevőit, az alapelemeket és a főbb kapcsolódási pontokat az 1.

5 HOZZÁFÉRÉS-VÉDELEM. A fejezet VIDEOTON fejlesztési dokumentációk felhasználásával készült

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

Vállalati integrált kockázatkezelés (II. rész)

Az üzemi méréstechnika hat szabálya

Tárgyi eszközök felhasználói leírás

Prezentáció használata

Hálózatkezelés Szolgáltatási minőség (QoS)

NeoCMS tartalommenedzselő szoftver leírása

KERESKEDELMI AJÁNLAT BUDAÖRSI VÁROSFEJLESZTŐ KFT. RÉSZÉRE KERETRENDSZERBEN KIALAKÍTOTT - PROJEKT MENEDZSMENT FUNKCIONALITÁS

Szoftver-ergonómiára vonatkozó szabvány, avagy ISO 9241

14. szám 122. évfolyam április 13. TARTALOM

IFJÚSÁG-NEVELÉS. Nevelés, gondolkodás, matematika

Általános áttekintés Készletek és paraméterek

FIR és IIR szűrők tervezése digitális jelfeldolgozás területén

Komponens alapú fejlesztés. Szoftvertechnológia elıadás

Models are not right or wrong; they are more or less useful.

HU Az Európai Unió Hivatalos Lapja L 102/35

Modellalkotás UML-ben

2. gyakorlat Állapot alapú modellezés Megoldások

Kapacitív áramokkal működtetett relés áramkörök S: B7:S21.3S2.$

Adminisztrátori kézikönyv (Ver: )

Átírás:

Szoftverprototípus készítése Dr. Mileff Péter A prototípus fogalma: a szoftverrendszer kezdeti verziója Mi a célja? Arra használják, hogy bemutassák a koncepciókat, kipróbálják a tervezési opciókat, jobban megismerjék a problémát és annak lehetséges megoldásait. A prototípus gyors, iteratív fejlesztése azért nagyon fontos, mert a költségek így ellenőrizhetők. 1 2 Szoftverprototípus készítése A szoftverprototípus több helyen is használható a fejlesztés folyamatában: 1. A követelménytervezés folyamatában. 2. A rendszertervezési folyamatban. 3. A tesztelési folyamatban. A követelmény fázisban: a prototípus fejlesztése alatt fény derülhet a követelményekkel kapcsolatos lehetséges hibákra, esetleg új ötletek kapcsán új rendszerkövetelményeket is indítványozhatnak. Szoftverprototípus készítése A rendszertervezési folyamatban: a rendszerprototípus felhasználható a tervezési tapasztalatok alkalmazására, illetve a javasolt terv megvalósíthatóságának felülvizsgálatára. Pl.: a gyors prototípus készítés az egyetlen módja annak, hogy a felhasználók bevonásával grafikus felhasználói felületeket fejlesszünk ki. 3 4 1

Szoftverprototípus készítése A rendszertesztelés fázisában: a prototípusok segítségével az eredmények ellenőrzéséhez szükséges munka visszacsatoló teszteksegítségével csökkenthető. Ilyenkor ugyanazokra a tesztesetekre futtatjuk a prototípust és a rendszert. Ha mindkét rendszer ugyanazt az eredményt adja, akkor a teszteset valószínűleg nem talált hibát. Szoftverprototípus készítése A prototípuskészítés rendszerint a szoftverfolyamat korai szakaszában növeli a költségeket, később viszont jelentősen csökkenti, mert elkerülhetők az újraírási munkák. A prototípuskészítés folyamata négykülönböző fázissal írható le: A prototípus céljainak megállapítása A prototípus funkcionalitásának definiálása A prototípus fejlesztése A prototípus kiértékelése 5 6 A négy fázis 1. A prototípuskészítés céljait érdemes az elején írásban megadni, e nélkül a vezetés vagy a végfelhasználók félreérthetik a rendeltetését. Ilyen cél lehet: az alkalmazás megvalósíthatóságának demonstrálása vagy a felhasználói felületek bemutatása, stb. Ugyanaz a prototípus nem szolgálhatja az összes célt. 2. Annak eldöntése, hogy mit tegyünk bele a prototípusba. 3. Prototípus kifejlesztése 4. A kiértékelés Gondoskodni kell a felhasználók képzéséről: Időbe telik, amíg megszokják az új rendszert csak ezután fedezhetik fel a követelménybeli hibákat és hiányosságokat. A két fő típus Két fő típusa: evolúciós és az eldobható. Az evolúciós prototípus célja: Egy működő rendszer átadása a végfelhasználóknak. Ezért a legjobban megértett és leginkább előtérbe helyezett követelményekkel kezd. Kevésbé fontos és körvonalazatlanabb követelmények: akkor kerülnek megvalósításra, amikor a felhasználók kérik. A módszer a weblapfejlesztés és az e-kereskedelmi alkalmazások szokásos technikája. 7 8 2

A két fő típus Az eldobható prototípus célja: jobban megértsük a megrendelő igényeit. a rendszerkövetelmények validálásavagy származtatása. A nem jól megértett követelményekkel érdemes kezdeni, mivel azokról szeretnénk többet megtudni. 9 10 Bevezetés A szoftvertervezés lényege:a szoftver logikai szerkezetére vonatkozó döntések meghozatala. Célszerű: bizonyos esetekben a logikai szerkezetet modellezőnyelv segítségévei ábrázolni Pl.: amilyen az UML (Unified Modeling Language). Más esetekben: a tervet informális jelölésrendszerrel leírt vázlatokkal reprezentáljuk. 11 12 3

Architektúrális tervezés A nagy rendszereket alrendszerekre bontják, amelyek biztosítják az egymással kapcsolatban lévő szolgáltatásokat. Architektúrálistervezés: ezen alrendszerek azonosításának és az alrendszer vezérlésére és kommunikációjára szolgáló keretrendszer létrehozásának kezdeti tervezési folyamata. 13 Architektúrális tervezés Kreatív folyamat: ahol megpróbálunk előállítani egy rendszerszerkezetet: amely megfelel a funkcionális és nem funkcionális rendszerkövetelményeknek. A rendszer architektúrája befolyásolja: a rendszer teljesítményét, robusztusságát, eloszthatóságát és karbantarthatóságát. Ezért fontos: a szoftvertervezőket rákényszerítsük arra, hogy a tervezés kulcsfontosságú aspektusaival már a folyamat korai szakaszában foglalkozzanak. 14 Architektúrális tervezés Az alkalmazás számára választott szerkezet: Függhet nem funkcionális rendszerkövetelményektől is. Pl.: teljesítmény, védettség, biztonságosság, rendelkezésre állás, és karbantarthatóság. Magában foglalja a rendszerek alrendszerekre bontását is: Az alrendszerek tervezése a rendszer durva szemcsézettségű komponensekre történő absztrakt felbontása, Ezen komponensek lehetnek önálló rendszerek. Az alrendszerek terveit általában blokkdiagram segítségével írjuk le. Tervezési döntések A tervezési folyamat során a rendszer tervezőinek számos döntést kell meghozniuk. amelyek alapvetően kihatnak a rendszerre és a fejlesztési folyamatra. Fontosabb felmerülő kérdések: 1. Létezik-e olyan általános alkalmazás architektúra, amely a tervezendő rendszer számára mintául szolgálhat? 2. Hogyan osztjuk szét a rendszert gépekre? 3. Milyen architektúrálisstílus lenne a rendszer számára megfelelő? 15 16 4

Tervezési döntések Tervezési döntések eredménye 4. Milyen alapvető megoldásokat alkalmazunk a rendszer strukturálására? 5. Hogyan lehet a rendszer szerkezeti egységeit modulokra felbontani? 6. Milyen stratégiát kell alkalmazni az egységek működésének vezérlésével kapcsolatban? 7. Hogyan értékelik majd ki az architektúrális tervet? 8. Hogyan kell a rendszer-architektúrát dokumentálni? A folyamat eredménye: egy architektúrális tervezési dokumentum Miket tartalmaz: A rendszer grafikus reprezentációit, és a hozzájuk kapcsolódó leíró szöveget. Annak a leírását, hogy a rendszert hogyan lehet alrendszerekre bontani, az egyes alrendszerek miképpen oszthatók modulokra. 17 18 Architektúrálismodellek 1. Statikus szerkezeti modell: megmutatja, hogyan lehet az alrendszereket és komponenseket különálló egységként fejleszteni. 2. Dinamikus folyamatmodell:ábrázolja, hogy a rendszer hogyan szervezhető futási idejű folyamatokba. Ez különbözhet a statikus modelltől. 3. Interfészmodell:az alrendszerek által publikus interfészeiken keresztül nyújtott szolgáltatásait írja le. 4. Kapcsolatmodellek:az alrendszerek közötti kapcsolatokat (például adatáramlás) mutatják be. 5. Elosztásimodell:azt adja meg, hogy az egyes alrendszereket hogyan kell elosztani a számítógépek között. A rendszer-architektúrák leírása: számos kutató az architektúra leíró nyelvek (architecturaldescriptionlanguages, ADL) használatát és az UML nyelvet javasolja. A rendszer felépítése A rendszer felépítését számos modell segítségével írhatjuk le. Pl.: Tárolási modell Kliens szerver modell Rétegzett modell Szolgáltatás orientált architektúra (SOA) Webszolgáltatások Egyéb 19 20 5

Moduláris felbontás 21 A teljes rendszer-architektúra kiválasztásra után, dönteni kell az alrendszerek modulokra bontásasorán alkalmazott megközelítésről. Az alrendszerek és modulok nem különböztethetők meg egyértelműen! Egy elképzelés: Alrendszer:egy olyan önálló rendszer, amely működése nem függ más alrendszerek szolgáltatásaitól. Az alrendszerek modulokból épülnek fel. Modul:olyan rendszerkomponens, amely más modulok számára szolgáltatás(oka)t biztosít. 22 Moduláris felbontás Az alrendszerek modulokra bontása során két fő stratégia ismeretes: 1. Objektumorientált felbontással a rendszert egymással kommunikáló objektumok halmazára bontjuk fel. 2. Funkcióorientált csővezetékekhasználatával a rendszert funkcionális modulokra bontjuk. bemenő adatokat fogadnak el és azokat kimenő adatokká alakítják. 23 Objektumorientált felbontás Az OO architekturális modell jellemzői: a rendszert lazán kapcsolódó, jól definiált interfészekkel rendelkező objektumok halmazára tagolja. Az objektumok a többi objektum által biztosított szolgáltatásokat hívják. Az OO felbontás: objektumosztályokkal, azok attribútumaival és műveleteivel foglalkozik. Implementációkor az objektumok ezekből az osztályokból jönnek létre, és az objektum műveleteinek koordinálásához valamilyen vezérlési modellt alkalmaznak. 24 6

Objektumorientált felbontás Objektumorientált felbontás Az OO megközelítés előnye: az objektumok lazán kapcsolódnak így az objektumok implementációja változtatható anélkül, hogy az hatással lenne más objektumokra. A komponensek közvetlen implementációjának biztosítására objektumorientált programozási nyelveket fejlesztettek ki. Pl.: C++, D, Objective Pascal, Java, stb. Hátránya: az objektumoknak explicit módon kell hivatkoznia a többi objektum nevére és interfészére. Ha a rendszerben interfész változtatás történt, akkor a változtatást minden, a megváltozott objektumot használó helyen át kell vezetni. 25 26 Vezérlési stílusok Ahhoz, hogy az alrendszerek rendszerként működjenek, vezérelni kell őket. hogy szolgáltatásaik a megfelelő helyre a megfelelő időben eljussanak. A strukturális modellek nem tartalmaznak ilyen elemeket ezért a rendszer kiépítőjének az alrendszereket valamilyen vezérlési modellnek megfelelően kell szerveznie. A vezérlési modellek az alrendszerek közötti vezérlési folyamatokkal foglalkoznak. 27 28 7

Vezérlési stílusok 1. Központosított vezérlés:a vezérlés teljes felelősségét egyetlen alrendszer látja el, amely beindítja és leállítja a többi alrendszert. 2. Eseményalapú vezérlés:a vezérlési információ nincs egyetlen alrendszerbe ágyazva minden alrendszer válaszolhat egy külsőleg létrejött eseményre. Ezek az események vagy más alrendszerekből, vagy a rendszer környezetéből származhatnak. A vezérlési stílusok kiegészítik a strukturális stílusokat. Minden korábban bemutatott strukturális stílust meg lehet valósítani mindkét vezérléssel egyaránt. Központosított vezérlés A központosított vezérlési modellben létezik egy kitüntetett alrendszer: a rendszervezérlő, A többi alrendszer végrehajtásáért felelős. A központosított vezérlési modellek két csoportba oszthatók: attól függően, hogy a vezérelt alrendszerek szekvenciálisanvagy párhuzamosan hajtódnak-e végre. 29 30 Központosított vezérlés A hívásvisszatérés modell 1. A hívás-visszatérés modell: A megszokott fentről le alprogram modellje: ahol a vezérlés az alprogram-hierarchia csúcsán kezdődik és alprogramhívások segítségével jut el a fa alsóbb szintjeire. Ez a modell csak szekvenciális rendszerek esetén alkalmazható. A vezérlés a hierarchiában magasabb szintű rutintól jut el az alacsonyabb szinten lévőhöz, majd visszatér a hívás helyére. 31 32 8

A hívásvisszatérés modell Központosított vezérlés A modell modulszinten használható a tevékenységek és objektumok vezérlésére, mert az OO rendszerben az objektumok műveletei eljárásként vagy függvényként vannak implementálva. A modell merev és korlátozott természete egyben előny és hátrány is. Erősségea vezérlési folyam elemzésének és bizonyos bemenet esetén a rendszer válasza kiszámíthatóságának viszonylagos egyszerűsége. Hátránya, hogy a normálistól eltérő működés esetén használata kényelmetlen. 2. A kezelőmodell: Konkurens és szekvenciális rendszerekre is alkalmazható. Egy kijelölt rendszerkezelő rendszerkomponens irányít: a többi rendszerfolyamat indítását, leállítását, valamint koordinálja azokat. Követelmény:egy folyamat olyan alrendszer vagy modul, amely végrehajtható más folyamatokkal párhuzamosan. 33 34 A kezelőmodell működése A rendszert vezérlő folyamat a rendszer állapotváltozói alapján dönt: az egyes folyamatokat mikor kell elindítani, illetve leállítani. Ellenőrzi: hogy a többi folyamat hozott-e létre feldolgozandó vagy feldolgozásra továbbküldendő információt. A vezérlő ciklikusan ellenőrzi az érzékelőket és folyamatokat, bekövetkezett-e valamilyen esemény vagy állapotváltozás. Éppen ezért ezt a modellt eseményciklus-modellnekis szokás nevezni. 35 36 9

Eseményvezérelt rendszerek Az eseményvezérelt vezérlési modelleket külsőleg létrehozott események irányítják. Az eseményvezérelt rendszereknek sok fajtája ismeretes, beleértve a szerkesztőket, ahol a szerkesztő utasításokat felhasználói felület események jelzik. 1. Eseményszóró modellek 2. Megszakítás-vezérelt modellek Eseményvezérelt rendszerek Eseményszóró modellek: egy esemény minden alrendszerhez eljut, és bármelyik, az esemény kezelésére programozott alrendszer reagálhat rá. A vezérlési politika nincs beépítve az esemény-és üzenetkezelőbe. Az alrendszerek eldöntik, hogy mely eseményekre tartanak igényt, az esemény-és üzenetkezelő pedig biztosítja, hogy ezek az események eljussanak hozzájuk. 37 38 Eseményvezérelt rendszerek Megszakítás-vezérelt modellek: Kizárólag valós idejű rendszerekben használják ahol egy megszakítás-kezelő észleli a külső megszakításokat. Ezek aztán valamely más komponenshez kerülnek feldolgozásra. 39 40 10

Objektumorientált tervezés Egy OO rendszer egymással együttműködő objektumokból áll, ahol az objektum saját állapotát karbantartja és erről az állapotról információs műveleteket biztosít. Az állapot reprezentációja privát, az objektumon kívülről közvetlenül nem hozzáférhető. Az OO tervezési folyamat: az objektumosztályoknak és az azok közötti kapcsolatoknak a megtervezéséből áll. 41 Objektumorientált tervezés Az OO tervezés az OO fejlesztés része a fejlesztési folyamat során objektumorientált stratégiát használunk: 1. Objektumorientált elemzés:a szoftver objektumorientált modelljének elemzésével foglalkozik. 2. Objektumorientált tervezés: a meghatározott követelményeknek megfelelő szoftverrendszer OO modelljének kialakítása. 3. Objektumorientált programozás: a szoftverterv objektumorientált programozási nyelven történő megvalósítása. Pl.: C++, D, Java. 42 Objektumorientált tervezés A különböző lépések közötti átmenetnek észrevehetetlennek kell lennie, Mindegyik lépésben kompatibilis jelölésrendszert kell használni. Az OO rendszereket a más elven fejlesztett rendszerekkel szemben könnyebb megváltoztatni, mert az objektumok egymástól függetlenek. Objektumorientált tervezés Egy objektum implementációjának megváltozása vagy új szolgáltatásokkal történő bővülése nem befolyásolhatja a rendszer többi objektumát. Ezért azt mondhatjuk, hogy az objektumok potenciálisan újrafelhasználható komponensek, mivel az állapotnak és a műveleteknek független egységbe zárásai. Ez növeli az érthetőséget és így a terv karbantarthatóságát is. 43 44 11

Objektumok és objektumosztályok Objektumok és objektumosztályok Ian Sommerville féle objektum definíció: Egy objektum egy állapottal és az ezen az állapoton ható, meghatározott műveletekkel rendelkező entitás. Az állapotot objektum-attribútumok halmazaként adjuk meg. Az objektum műveletei szolgáltatásokat biztosítanak a többi objektum számára. Az objektumok egy objektumosztály-definíció alapján jönnek létre. Egy objektumosztály definíciója egyszerre típusspecifikáció és egy objektumok létrehozására szolgáló sablon. Az adott osztályba tartozó objektummal kapcsolatos összes attribútum és művelet deklarációját tartalmazza. 45 46 UML-ben megadott osztálydefiníció Objektumok és objektumosztályok Az objektumok kommunikációja: szolgáltatásokat kérnek más objektumoktól (meghívják azok módszereit). A szolgáltatás végrehajtásához szükséges információ és a szolgáltatás végrehajtásának eredményei paraméterként adódnak át. Pl.: Az Alkalmazott objektumosztály 47 // Egy puffer objektum módszerének hívása, amely visszaadja a pufferben található következő értéket v = Buffer.GetNextElement(); // Puffer elemszámának a beállítása v = Buffer.SetElements(20); 48 12

Szolgáltatás igénylése Egy objektum szolgáltatáskérés üzenetet küldhet egy másiknak, akitől a szolgáltatást kéri. A fogadóobjektum: elemzi az üzenetet azonosítja a szolgáltatást és az ahhoz kapcsolódó adatokat, majd végrehajtja a kívánt szolgáltatást. Ha a szolgáltatáskérelmek ily módon vannak implementálva, az objektumok közötti kommunikáció szinkron, azaz a hívóobjektum megvárja a szolgáltatás befejeződését (soros végrehajtás). A gyakorlatban a legtöbb objektum-orientált nyelvben ez a modell az alapértelmezett. Objektumok és objektumosztályok Az újabb OOP nyelvekben (pl. JAVA,) azonban léteznek a szálak, amelyek megengedik a konkurens módon végrehajtódó objektumok létrehozását és az aszinkron kommunikációt (a hívóobjektum folytatja a működését az általa igényelt szolgáltatás futása alatt is). Ezek a konkurens objektumok kétféleképpen implementálhatók: Aktív objektumok vagy Szerverek. 49 50 Objektumok és objektumosztályok 1. Aktív objektumok: önmaguk képesek belső állapotukat megváltoztatni és üzenetet küldeni, anélkül, hogy más objektumtól vezérlőüzenetet kaptak volna. (Ellentétük a passzív objektum.) Az aktív objektumot reprezentáló folyamat ezeket a műveleteket folyamatosan végrehajtja, így soha nem függesztődik fel. Objektumok és objektumosztályok 2. Szerverek: az objektum a megadott szolgáltatásokkal rendelkező párhuzamos folyamat. Az eljárások egy külső üzenetre válaszolva indulnak el és más objektumok eljárásaival párhuzamosan futhatnak. Mikor befejezték a tevékenységüket, az objektum várakozó állapotba kerül és további kéréseket vár. 51 52 13

Szerverek alkalmazásai Aktív objektumok alkalmazásai A szervereket leginkább osztott környezetben érdemes használni ahol a hívó és a hívott objektum különböző számítógépeken hajtódik végre. Az igényelt szolgáltatásra adott válaszidő megjósolhatatlan úgy kell megtervezni a rendszert, hogy a szolgáltatást igénylő objektumnak ne kelljen megvárni a szolgáltatás befejeződését. A szerverek persze egyedi gépen is használhatók ahol a szolgáltatás befejeződéséhez némi időre van szükség pl. nyomtatás Aktív objektumokat akkor célszerű használni ha egy objektumnak saját állapotát megadott időközönként frissíteni kell. Ez valós idejű rendszerekben gyakori az objektumok ott a rendszer környezetéről információt gyűjtő hardvereszközökkel állnak kapcsolatban. 53 54 Objektumok és objektumosztályok Az objektumosztályok egy generalizációsvagy öröklődési hierarchiába szervezhetők, az általános és a specifikus objektumosztályok közötti kapcsolatot jeleníti meg. A hierarchiában a lejjebb található osztályok: rendelkeznek ugyanazokkal az attribútumokkal és műveletekkel, mint szülőosztályaik, de új attribútumokkal és műveletekkel egészítheti ki azokat, valamint meg is változtathatják szülőosztályaik attribútumainak és műveleteinek némelyikét. Objektumok élettartalma Egy objektum belső állapotát az attribútumainak pillanatnyi értéke határozza meg. Perzisztensobjektumok: A háttértárolón azon objektumok adatait kell tárolni, amelyek élettartama hosszabb, mint a program futási ideje. Tranziens objektumok: Azon objektumok, amelyek élettartama a program futási idejénél nem hosszabb. Ha a program nagyszámú perzisztensobjektummal dolgozik, érdemes egy adatbázis-kezelő rendszerrel kiegészíteni. 55 56 14

57 15