„Objektumorientált szoftvertervezés - Vizsga, 2010.05.26.” változatai közötti eltérés
Új oldal, tartalma: „{{GlobalTemplate|Infoszak|OotVizsga20100526}} ===OO Vizsga 2010-05-26=== __TOC__ ====01. Egy szokásos "milyen értékek kerülnek perzisztálásra" feladat==== (ob…” |
a Hryghr átnevezte a(z) OotVizsga20100526 lapot a következő névre: Objektumorientált szoftvertervezés - Vizsga, 2010.05.26. |
||
| (2 közbenső módosítás, amit egy másik szerkesztő végzett, nincs mutatva) | |||
| 1. sor: | 1. sor: | ||
===OO Vizsga 2010-05-26=== | ===OO Vizsga 2010-05-26=== | ||
__TOC__ | __TOC__ | ||
==== | ====Egy szokásos "milyen értékek kerülnek perzisztálásra" feladat==== | ||
(objektum különféle tagváltozóit módosítgatjuk, majd kiírjuk egy ObjectOutputStreamre, utána visszaolvassuk, ezután mennyi az egyes tagváltozók értéke). | (objektum különféle tagváltozóit módosítgatjuk, majd kiírjuk egy ObjectOutputStreamre, utána visszaolvassuk, ezután mennyi az egyes tagváltozók értéke). | ||
==== | ====A Netbeanses JPA-s autós példában milyen szerepet töltött be a Buffer? (Válaszát röviden indokolja) ==== | ||
* interfész | * interfész | ||
| 16. sor: | 14. sor: | ||
* session bean | * session bean | ||
==== | ====Két package adott volt, a függőségeik alapján Instability (RMI) számítása.==== | ||
* RMI = CE / ( CA + CE ) | * RMI = CE / ( CA + CE ) | ||
| 25. sor: | 23. sor: | ||
* Y a két package közt másik irányban a függőségek száma. | * Y a két package közt másik irányban a függőségek száma. | ||
==== | ====Function Point elemzés fázisai.==== | ||
Funkciópont elemzés (6. diasor/ 34 dia) komponensei: | Funkciópont elemzés (6. diasor/ 34 dia) komponensei: | ||
| 34. sor: | 32. sor: | ||
* External Interface Files | * External Interface Files | ||
==== | ====Milyen táblákba képződik le a megadott struktúra (1 ős és két gyermekosztállyal) table-per-subclass leképezés esetén?==== | ||
* Minden külön táblába, a 1 ős osztályban lesz discriminator, valamint a gyermek osztályokban lesz egy ID attribútum, ami az ősre mutat. | * Minden külön táblába, a 1 ős osztályban lesz discriminator, valamint a gyermek osztályokban lesz egy ID attribútum, ami az ősre mutat. | ||
* Discriminator nem szükséges, diákon sem volt: http://docs.jboss.org/hibernate/core/3.3/reference/en/html/inheritance.html#inheritance-tablepersubclass-discriminator | * Discriminator nem szükséges, diákon sem volt: http://docs.jboss.org/hibernate/core/3.3/reference/en/html/inheritance.html#inheritance-tablepersubclass-discriminator | ||
==== | ====Strategized locking minta milyen problémát hogy old meg, UML class diagram.==== | ||
* Probléma: | * Probléma: | ||
| 51. sor: | 49. sor: | ||
* UML ábra -> diasor | * UML ábra -> diasor | ||
==== | ====Adott egy X osztály, ami aggregál egy Z osztályt, aki megvalósítja a Cloneable interfészt. Meg kell adni az X osztályra vonatkozó clone() függvényt, és garantálni kell, hogy az deep copy-t végezzen.==== | ||
<pre> | <pre> | ||
| 61. sor: | 59. sor: | ||
</pre> | </pre> | ||
==== | ====Deadlock-hoz vezet-e az alábbi kódrészlet?==== | ||
<pre> | <pre> | ||
| 94. sor: | 92. sor: | ||
</pre> | </pre> | ||
==== | ====Mik a SAX alapvető jellemzői? (3p)==== | ||
* Eseményvezérelt, callback (ContentHandler) | * Eseményvezérelt, callback (ContentHandler) | ||
| 100. sor: | 98. sor: | ||
* Állapotfüggetlen feldolgozás | * Állapotfüggetlen feldolgozás | ||
==== | ====Milyen tervezési mintákat valósítanak meg? (5p)==== | ||
* RMI stub - proxy | * RMI stub - proxy | ||
| 108. sor: | 106. sor: | ||
* AWT eseménykezelés - observer | * AWT eseménykezelés - observer | ||
==== | ====A SwingWorkerre miért van szükség és kinek a felelőssége meghívni a process() és publish() metódusokat? (3p)==== | ||
* Java -> Swing fejezet -> szálkezelés téma | * Java -> Swing fejezet -> szálkezelés téma | ||
| 126. sor: | 124. sor: | ||
* publish()-t meghívod a doInBackground() metódusban, tehát NEM az eseménykezelőben, hanem a külön szálban és a [[SwingWorker]] megoldja, hogy az eseménykezelő szálból történjen egy process() hívás, ami tartalmaz egy vagy több publish()-nak átadott elemet (ilyenkor ezeket pl. hozzá lehet adni a [[GUIn]] egy listához, stb), itt egy példa: http://download.oracle.com/javase/6/docs/api/javax/swing/SwingWorker.html | * publish()-t meghívod a doInBackground() metódusban, tehát NEM az eseménykezelőben, hanem a külön szálban és a [[SwingWorker]] megoldja, hogy az eseménykezelő szálból történjen egy process() hívás, ami tartalmaz egy vagy több publish()-nak átadott elemet (ilyenkor ezeket pl. hozzá lehet adni a [[GUIn]] egy listához, stb), itt egy példa: http://download.oracle.com/javase/6/docs/api/javax/swing/SwingWorker.html | ||
==== | ====Verziókezeléses módszerek, előnyei, hátrányai. Ha jól emlékszem, ez a kérdés a weave, delta, stb.-re kérdezett rá. CsL(3p)==== | ||
* Írj a témáról amit jólesik, 3 pontért. <br> | * Írj a témáról amit jólesik, 3 pontért. <br> | ||
==== | ====Reverse skip deltás példa. Mely revíziókat hogyan tároljuk el a 20., legutolsó revízióhoz képest? (3p)==== | ||
A megoldás menete: minden új verziónál megnézzük, hogy hány záró 0 van a bináris alakjában, és hozzáadunk egyet, ennyi korábbi verzióhoz kell új deltát csinálni. Az újradeltázandó verziók a friss verzióból a 2 hatványok, de csak annyi, amit az előbb kiszámoltunk (x-1, x-2, x-4, x-8 ...) | A megoldás menete: minden új verziónál megnézzük, hogy hány záró 0 van a bináris alakjában, és hozzáadunk egyet, ennyi korábbi verzióhoz kell új deltát csinálni. Az újradeltázandó verziók a friss verzióból a 2 hatványok, de csak annyi, amit az előbb kiszámoltunk (x-1, x-2, x-4, x-8 ...) | ||
| 137. sor: | 135. sor: | ||
*20*:(19,18,16) *18*:(17) *16*:(15,14,12,8,0) *14*:(13) *12*:(11,10,4) *10*:(9) *8*:(7,6) *6*:(5) *4*:(3,2) *2*:(1) | *20*:(19,18,16) *18*:(17) *16*:(15,14,12,8,0) *14*:(13) *12*:(11,10,4) *10*:(9) *8*:(7,6) *6*:(5) *4*:(3,2) *2*:(1) | ||
==== | ====A kulcsokat miért Set-ben, az értékeket miért Collection-ben adják vissza a Map interfészt megvalósító Java osztályok? (1p)==== | ||
* Kulcsok - a kulcsokra érvényes az unicitás törvénye, azaz egyediséget biztosítanak, és egy értéktípusból egy szerepelhet. Ennek biztosításához egy halmaz-tulajdonságú adatszerkezet szükségeltetik, és a Set pontosan ilyen. | * Kulcsok - a kulcsokra érvényes az unicitás törvénye, azaz egyediséget biztosítanak, és egy értéktípusból egy szerepelhet. Ennek biztosításához egy halmaz-tulajdonságú adatszerkezet szükségeltetik, és a Set pontosan ilyen. | ||
| 144. sor: | 142. sor: | ||
Avagy ezeket lehet változtatgatni. [[CsL]] | Avagy ezeket lehet változtatgatni. [[CsL]] | ||
==== | ====Choice(Identity, v) = ? ==== | ||
= Identity | = Identity | ||