Java RMI Áttekintés. A Java RMI. A Java RMI architektúrája. Ficsor Lajos. Általános Infromatikai Tanszék Miskolci Egyetem 1.
|
|
- Oszkár Takács
- 5 évvel ezelőtt
- Látták:
Átírás
1 Java RMI Áttekintés Miskolci Egyetem Általános Informatikai Tanszék RMI /1 A Java RMI RPC - egy távoli eljárás hívása helyi hívásnak tÿnik RMI - hasonló mechanizmust biztosít, de objektum orientált módon: egy távoli objektum metódusának hívása helyi objektum használatának tÿnik A Java nyelvnek nincs speciális IDL-je, ehelyett minden remote interface a java.rmi.remote interface-t terjeszti ki Java RMI (Áttekintés) RMI /2 A Java RMI architektúrája Alkalmazás Client Server Stubs Skeletons Remote Reference Layer Transport Layer Java RMI (Áttekintés) RMI /3 Miskolci Egyetem 1
2 Az RMI architektúra elemei Stubs A kliens hivatkozása a távoli objektumra valójában hivatkozás a helyi csonkra. A csonk meghívja a Remote Reference Layer-t átalakítja (marshals) az argumentumokat értesíti a Remote Reference Layer-t hogy a hívás továbbítható visszaalakítja (unmarshals) a visszatérési értéket vagy a kivételt értesíti a Remote Reference Layer-t, hogy a hívás befejez dött. Java RMI (Áttekintés) RMI /4 Az RMI architektúra elemei (folyt.) Skeleton Tartalmaz egy metódust, amely továbbítja a hívásokat az aktuális távoli objektumok implementációjának: visszaalakítja (unmarshals) az argumentumokat meghívja az aktuális távoli objektum implementációját átalakítja (marshals) a visszatérési értéket vagy a kivételt Java RMI (Áttekintés) RMI /5 Az RMI architektúra elemei (folyt.) Remote reference layer A specifikus távoli hivatkozás protokoll végrehajtásáért felel s. Minden távoli objektum saját távoli hivatkozás osztályt választ, amely a kéréseit végrehajtja. Számos hívási protokoll választható ebben a rétegben. Például: unicast point-to-point invocation invocation to replicated object groups support for a specific replication strategy support for a persistent reference to the remote object (enabling activation of the remote objectum) reconnection strategies Java RMI (Áttekintés) RMI /6 Miskolci Egyetem 2
3 Az RMI architektúra elemei (folyt.) Transport layer A távoli címtartománnyal való kapcsolat létrehozása A kapcsolat menedzselése A kapcsolat "él " voltának figyelése Abejöv hívások figyelése Az címtartományhoz tartozó távoli objektumok táblázatának karbantartása Kapcsolat létrehozása egy bejöv híváshoz A távoli hívás céljának megfelel elosztó (dispatcher) megkeresése és a kapcsolat átadása a dispatcher-nek. Java RMI (Áttekintés) RMI /7 Az RMI egyéb jellemzÿi Fonál használat az RMI-ben A szerver külön szálban, vagy azonos szálban is futhat Szemétgyÿjt mechanizmus a távoli objektumokra is Dinamikus osztálybetöltés Remote objektumok és interface-eik osztályára Stub és skeleton osztályokra Egyéb, az RMI által használt osztályokra (paraméterek, visszatérési értékek) Java RMI (Áttekintés) RMI /8 RMI kliens és szerver fejlesztése 8 Kliens implementálása (.java) 9 javac 1 Kliens alk. (.class) 10 Kliens indítása Remote interface definiálása uses 2 Interface implementálása (.java) 3 javac User 4 rmic Kliens stub (.class) User feladata Generált elem Program feladata Manuális tev. Jelölés Szerver osztály (.class) Szerver skeleton (.class) 5 RMI registry indítása 6 Szerver objektum aktivizálása 7 Távoli objektum regisztrálása Java RMI (Áttekintés) RMI /9 Miskolci Egyetem 3
4 A fejlesztés lépései 1. A távoli interface definiálása A távoli objektum interface-ének definiálása Java interface-ként A java.rmi.remote interface-t kell kiterjesztenie Minden metódusának dobnia kell a java.rmi.remoteexception kivételt Java RMI (Áttekintés) RMI /10 A fejlesztés lépései (folyt.) 2. A távoli interface implementálása A Java server osztály megírása Az el bbi interface-t kell implementálnia A java.rmi.unicastremoteobject osztály leszármazottja kell legyen 3. A szerver osztály lefordítása 4. A stub compiler futtatása Anevermic, paraméterei azonosak a javac-vel Generálja a kliens stub-ot és a szerver skeletont. Java RMI (Áttekintés) RMI /11 A fejlesztés lépései (folyt.) 5. RMI registry indítása rmiregistry parancs a szerver gépen Lehet vé teszi a távoli objektum név szerinti elérését Ez is távoli objektumként van implementálva Minden szerver processz használhat saját registry-t vagy egy közöset A registry kezdetben üres, a távoli objektumokat a szerver processz(ek)nek kell bejegyeznie Java RMI (Áttekintés) RMI /12 Miskolci Egyetem 4
5 A fejlesztés lépései (folyt.) 6. Szerver processz indítása A szerver processz létrehozza a szerver objektum példányát vagy példányait 7. Távoli objektumok regisztrációja A szerver processz bejegyzi a távoli objektumokat a registry-be Ehhez a java.rmi.naming osztály metódusait használhatja A szerver ezzel kész fogadni a kliensek kapcsolódását Java RMI (Áttekintés) RMI /13 A fejlesztés lépései (folyt.) 8. Kliens kód megírása A távoli objektum megkereséséhez használnia kell a java.rmi.naming osztály metódusait A távoli objektum használata ezután ugyanolyan, mint a lokális objektumoké 9. Kliens kód lefordítása 10. Kliens indítása Java RMI (Áttekintés) RMI /14 RMI interface-ek ek és osztályok RMI-vel kapcsolatos csomagok (több, mint 25 osztály és interface): java.rmi java.rmi.server java.rmi.dgc java.rmi.registry Három funkcionális kategória: RMI alapok RMI security RMI marshalling Java RMI (Áttekintés) RMI /15 Miskolci Egyetem 5
6 RMI alap osztályok és interface-ek ek Remote Object osztály (from java.lang) IOException osztály (from Java.io) (from java.rmi) <<implements>> RemoteObject (from java.rmi.server) RemoteException RemoteStub (from j ava.rmi.server) RemoteObject() equals() tostring() RemoteServer (from java.rmi.server) (from java.rmi ) RemoteException() getmessage() RemoteStub() setref() <<uses>> RemoteServer() getclienthost() getlog() setlog() UnicastRemoteObject (from java.rmi. server) Kliens osztály Szerver osztály Unicas tremoteobject() exportobject() clone() Java RMI (Áttekintés) RMI /16 RMI alap osztályok feladata Remote interface Nincs egyetlen metódusa sem. Csak jelz. Minden remote objektumnak implementálnia kell RemoteObject osztály A Java Object osztály szerepét tölti be a távoli objektumokra RemoteStub osztály A kliens objektum(ok) közvetlen sosztálya Elrejti a szerver objektummal való kapcsolatot az t használó objektumok el l. Java RMI (Áttekintés) RMI /17 RMI alap osztályok feladata (folyt.) RemoteServer osztály Szerver objektumok létrehozása és exportálása (elérhet vé tétele) A szerver implementációk közös bázisosztálya UnicastRemoteObject osztály A távoli szerver objektum implementációja, az alábbi tulajdonságokkal: Tranziens objektum összeköttetés alapú TCP protokollt használ a kommunikációra A szerver osztály sosztálya kell legyen Java RMI (Áttekintés) RMI /18 Miskolci Egyetem 6
7 RMI alap osztályok feladata (folyt.) RemoteException osztály Az RMI által kiváltható valamennyi kivétel sosztálya A remote interface valamennyi metódusánál specifikálni kell Java RMI (Áttekintés) RMI /19 RMI Naming szolgáltatás Object osztály (from java.lang) Remote (from java.rmi) Registry (from java.rmi.registry) lookup() bind() unbind() rebind() LocateRegistry (from java.rmi.registry) getregistry() createregistry() Naming (from java.rmi.registry) lookup() bind() unbind() rebind() list() Java RMI (Áttekintés) RMI /20 A naming szolgáltatás használata Többnyire csak a Naming osztályt használjuk. Azonosítás URL formátumú: rmi://host:port/objektumnev Default port: 1099 A kliens a lookup metódust használja a távoli objektum referencia megszerzésére: Remote lookup(string name) A szerver a bind vagy rebind metódust használja a szerver objektum regisztrálására: void bind(string name, Remote obj) Java RMI (Áttekintés) RMI /21 Miskolci Egyetem 7
8 Az RMI forgatókönyve Kliens oldal Szerver oldal Kliens System Naming System Szerver 1. setsecuritymanager 2. rebind 3. setsecuritymanager 4. lookup Proxy download szerver 5. metódus hívás metódus hívás Java RMI (Áttekintés) RMI /22 Az RMI forgatókönyve (folyt.) 1. A szerver engedélyezi az RMI Security Manager mÿködését: létrehoz egy új RMISecurityManager objetumot és átadja a System objektumnak 2. A szerver regisztrálja magát a névszolgáltatónál 3. A kliens is engedélyezi az RMI Security Managert a saját rendszerében Java RMI (Áttekintés) RMI /23 Az RMI forgatókönyve (folyt.) 4. A kliens megkeresi a távoli objektumot Kiad egy lookup hívást a Naming objektumnak, és megadja a kivánt szerver URL nevét A metódus visszad egy referenciát a proxy szerverre Ha szükséges, a kliens oldali stub letölt dik 5. A kliens meghívja a távoli objektum metódusát A hívás a proxy szerver objektumhoz fut be A proxy szerver továbbítja a hívást a stub segítségével A hívás eredménye visszaérkezik szintén a stub segítségével Java RMI (Áttekintés) RMI /24 Miskolci Egyetem 8
9 Egyszer példa Ebben a példában a távoli objektum egy számlálóval rendelkezik. A számláló adott értékre beállítható, inkrementálható, lekérdezhet. Egy kliens ezt a távoli objektumot használva nullázza a számlálót, ezerszer inkrementálja, majd lekérdezi az értékét. A szerver helye a kliens program paramétere. Java RMI (Áttekintés) RMI /25 Példa: távoli interface A távoli objektum interface-e: public interface CountRMI extends java.rmi.remote public int sum() throws java.rmi.remoteexception; public void sum(int val) throws java.rmi.remoteexception; public int increment() throws java.rmi.remoteexception; Java RMI (Áttekintés) RMI /26 Példa: kliens program import java.rmi.*; import java.rmi.registry.*; import java.rmi.server.*; public class CountRMIClient public static void main(string args[]) // Security manager beállítása System.setSecurityManager(new RMISecurityManager()); Java RMI (Áttekintés) RMI /27 Miskolci Egyetem 9
10 Példa: kliens program (folyt.) // Referencia szerzese a tavoli objektumra try CountRMI mycount = (CountRMI)Naming.lookup("rmi://" + args[0] + "/" + "my CountRMI"); // Megjegyzesek: // a fenti castolas szukseges es lehetseges // innentol kezdve a mycount ugyanugy // hasznalhato, mint egy helyi referencia // szamlalo nullazasa System.out.println("Setting Sum to 0"); mycount.sum(0); // Mint egy helyi hivas Java RMI (Áttekintés) RMI /28 Példa: kliens program (folyt.) // Incrementalas 1000-szer System.out.println("Incrementing"); for (int i = 0 ; i < 1000 ; i++ ) mycount.increment(); System.out.println("Sum = " + mycount.sum()); // Kivetel kezelese catch(exception e) System.err.println("System Exception" + e); System.exit(0); Java RMI (Áttekintés) RMI /29 Szerver objektum implementációja import java.rmi.*; import java.rmi.server.unicastremoteobject; public class CountRMIImpl extends UnicastRemoteObject implements CountRMI // Adattag private int sum; Java RMI (Áttekintés) RMI /30 Miskolci Egyetem 10
11 Szerver objektum impl. (folyt.) public CountRMIImpl(String name) throws RemoteException super(); try // Az objektum regisztralasa Naming.rebind(name, this); sum = 0; catch (Exception e) System.out.println("Exception: "+ e.getmessage()); Java RMI (Áttekintés) RMI /31 Szerver objektum impl. (folyt.) // Tavolrol is elerheto metodusok public int sum() throws RemoteException return sum; public void sum(int val) throws RemoteException sum = val; public int increment() throws RemoteException sum++; return sum; Java RMI (Áttekintés) RMI /32 Szerver objektum inicializálása import java.rmi.*; import java.rmi.server.*; public class CountRMIServer public static void main(string args[]) // Security manager letrehozasa es inditasa System.setSecurityManager(new RMISecurityManager()); Java RMI (Áttekintés) RMI /33 Miskolci Egyetem 11
12 Szerver objektum inicializálása (folyt.) try // CountRMIImpl peldagny letrehozasa CountRMIImpl mycount = new CountRMIImpl("my CountRMI"); System.out.println("CountRMI Server ready."); catch (Exception e) System.out.println("Exception: " + e.getmessage()); e.printstacktrace(); Java RMI (Áttekintés) RMI /34 Apélda futtatása Lefordítjuk az összes modult (feltételezve, hogy a java file-ok katalógusában vagyunk) javac CountRMI.java javac CountRMIClient.java javac CountRMIImpl.java javac CountRMIServer.java Futatjuk a stub compilert rmic CountRMIImpl Elindítjuk az RMI registry-t rmiregistry Elindítjuk a szervert majd a klienst Java RMI (Áttekintés) RMI /35 Hivatkozások Csizmazia Balázs: Hálózati alkalmazások készítése (második kiadás), 6. fejezet Kiadó: Kalibán Bt., Budapest ISBN Sok szerz : JAVA 2 útikalauz programozóknak. (Hatodik kiadás) 21. Fejezet Kiadó: ELTE TTK Hallgatói Alapítvány Budapest, 2000 ISBN Java RMI (Áttekintés) RMI /36 Miskolci Egyetem 12
13 Hivatkozások (folyt.) Robert Orfali, Dan Harkey: Client/Sserver Programming with JAVA and CORBA (Second Edition) Chapter 13. John Wiley & Sons, 1998 ISBN X Java RMI (Áttekintés) RMI /37 Miskolci Egyetem 13
Java RMI Áttekintés. Miskolci Egyetem Általános Informatikai Tanszék. Utolsó módosítás: Ficsor Lajos. javarmi / 1
Java RMI Áttekintés Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2008. 03. 05. javarmi / 1 A Java RMI RPC - egy távoli eljárás hívása helyi hívásnak tűnik RMI - hasonló mechanizmust
RészletesebbenR I Szer e i r alizáció.
Bevezetés Java RMI Párhuzamos és Elosztott rendszerek II. Dr. Mileff Péter A számítógép-hálózatok rohamos terjedésével a hálózattal összekapcsolt számítógépekbıl álló rendszerek egyre népszerőbbek: Erıforrás
RészletesebbenJava Remote Method Invocation API
RMI Java Remote Method Invocation API RMI Java RMI API(Java Remote Method Invocation API): távoli (remote) objektumok metódusainak meghívását lehetővé tevő fejlesztői interfész (API) Kétfajta implementációja
RészletesebbenSegédanyag: Java alkalmazások gyakorlat
Segédanyag: Java alkalmazások gyakorlat Készítette: Szabó Attila 2009/2010-2 félév, 12. gyakorlat 1 Távoli metódushívás Java-ban (RMI) Java-ban a távoli metódushívás ( Remote Method Invocation, RMI) egy
RészletesebbenSegédanyag: Java alkalmazások gyakorlat
Segédanyag: Java alkalmazások gyakorlat Készítette: Szabó Attila 2010/2011-2 félév, 11. gyakorlat (az előző 2 gyak közül az egyiken ZH volt, a másik szünet miatt elmaradt) 1 JAR fájl készítés A JAR (Java
RészletesebbenCORBA Áttekintés. Mi a CORBA? OMG and OMA. Ficsor Lajos. Miskolci Egyetem Általános Informatikai Tanszék
CORBA Áttekintés Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2007. 10. 15. Mi a CORBA? osztott objektum modell szabvány, amely definiálja a komponensek közötti interface-eket definiál
RészletesebbenKommunikáció. Folyamatok közötti kommunikáció. Minden elosztott rendszer alapja
Kommunikáció Folyamatok közötti kommunikáció Minden elosztott rendszer alapja Marshalling Alap primitívek Direkt, indirekt portok Blokkolás, nem blokkolás Pufferelés Megbízhatóság RPC Az RPC jellemzői
RészletesebbenPárhuzamos és Elosztott Rendszerek II
Párhuzamos és Elosztott Rendszerek II JAVA RMI Készítette: Dr. Mileff Péter Miskolci Egyetem Általános Informatikai Tanszék 1. Bevezetés A számítógép-hálózatok rohamos terjedésével a hálózattal összekapcsolt
RészletesebbenElosztott rendszerek
Elosztott rendszerek NGM_IN005_1 Köztesréteg megoldások (middleware-ek) Middleware alapú elosztott rendszerek Magas átlátszósági fok Eltér! operációs rendszerek Modellfügg! kommunikációs mechanizmus Er!forráskezelés
RészletesebbenDCOM Áttekintés. Miskolci Egyetem Általános Informatikai Tanszék. Ficsor Lajos DCOM /1
DCOM Áttekintés Miskolci Egyetem Általános Informatikai Tanszék DCOM /1 Mi a DCOM? DCOM: Distributed Component Object Model A Microsoft osztott objektum modellje Bináris együttmÿködési szabvány és annak
RészletesebbenRMI = Remote Method Invocation. Java tutorial. Kliens-szerver forgato kő nyv. Elosztott objektumok rendszere forgato kő nyv.
RMI = Remote Method Invocation í Meg tudjuk hıvni olyan objektumok meto dusait is, amelyek mas virtualis gepben futnak í Kommunikacio kulő nbő z gepeken futo Java programok kő ző tt Kliens-szerver alkalmazasok
RészletesebbenOsztott alkalmazások fejlesztési technológiái Áttekintés
Osztott alkalmazások fejlesztési technológiái Áttekintés Ficsor Lajos Általános Informatikai Tanszék Miskolci Egyetem Történelem - a kezdetek 2 Mainframe-ek és terminálok Minden a központi gépen fut A
RészletesebbenJNDI - alapok. Java Naming and Directory Interface
JNDI - alapok Java Naming and Directory Interface Naming Service Naming service: nevek hozzárendelése objektumokhoz, elérési lehetőség (objektumok/szolgáltatások lokalizálása), információk központosított
RészletesebbenA Java nyelv. V. rész Az objektumorientáltság magasabb fokú tulajdonságai: Perszisztencia, CORBA, RMI
A Java nyelv V. rész Az objektumorientáltság magasabb fokú tulajdonságai: Perszisztencia, CORBA, RMI A Java a jövő programozási nyelve. A jövőt azonban csak a jelenen keresztül, a múlt felhasználásával
RészletesebbenEnterprise JavaBeans. Ficsor Lajos Általános Informatikai Tanszék Miskolci Egyetem. Az Enterprise JavaBeans
Enterprise JavaBeans Ficsor Lajos Általános Informatikai Tanszék Miskolci Egyetem Az Enterprise JavaBeans Az Enterprise Javabeans Az Enterprise JavaBeans (EJB) server oldali komponens, amely Az üzleti
RészletesebbenOsztálytervezés és implementációs ajánlások
Osztálytervezés és implementációs ajánlások Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2006. 04. 24. Osztálytervezés és implementációs kérdések OTERV / 1 Osztály tervezés Egy nyelv
RészletesebbenOsztálytervezés és implementációs ajánlások
Osztálytervezés és implementációs ajánlások Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2006. 04. 24. Osztálytervezés és implementációs kérdések OTERV / 1 Osztály tervezés Egy nyelv
RészletesebbenEnterprise JavaBeans 1.4 platform (EJB 2.0)
Enterprise JavaBeans 1.4 platform (EJB 2.0) Ficsor Lajos Általános Informatikai Tanszék Miskolci Egyetem Utolsó módosítás: 2007. 11.13. Az Enterprise JavaBeans Az Enterprise Javabeans Az Enterprise JavaBeans
Részletesebbenés az instanceof operátor
Java VIII. Az interfacei és az instanceof operátor Krizsán Zoltán Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2005. 10. 24. Java VIII.: Interface JAVA8 / 1 Az interfészről általában
RészletesebbenAbstract osztályok és interface-ek. 7-dik gyakorlat
Abstract osztályok és interface-ek 7-dik gyakorlat Abstract metódusok és osztályok Az OO fejlesztés során olyan osztályokat is kialakíthatunk, melyeket csak továbbfejlesztésre, származtatásra lehet használni,
RészletesebbenJava VIII. Az interfacei. és az instanceof operátor. Az interfészről általában. Interfészek JAVA-ban. Krizsán Zoltán
Java VIII. Az interfacei és az instanceof operátor Krizsán Zoltán Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2005. 10. 24. Java VIII.: Interface JAVA8 / 1 Az interfészről általában
RészletesebbenAz osztályok csomagokba vannak rendezve, minden csomag tetszőleges. Könyvtárhierarhiát fed: Pl.: java/util/scanner.java
Függvények, csomagok Csomagok Az osztályok csomagokba vannak rendezve, minden csomag tetszőleges számú osztályt tartalmazhat Pl.: java.util.scanner Könyvtárhierarhiát fed: Pl.: java/util/scanner.java Célja:
RészletesebbenKomponens modellek. 3. Előadás (első fele)
Komponens modellek 3. Előadás (első fele) A komponens modellek feladata Támogassa a szoftverrendszerek felépítését különböző funkcionális, logikai komponensekből, amelyek a számítógépes hálózatban különböző
RészletesebbenOOP: Java 8.Gy: Abstract osztályok, interfészek
OOP: Java 8.Gy: Abstract osztályok, interfészek 26/1 B ITv: MAN 2019.04.03 Abszrakt metódus és absztrakt osztály. Gyakran előfordul a tervezés során, hogy egy osztály szintjén tudjuk, hogy valamilyen metódus
RészletesebbenProgramozási nyelvek Java
Programozási nyelvek Java Kozsik Tamás előadása alapján Készítette: Nagy Krisztián 13. előadás Throwable Error Exception RuntimeException IOException Saját (általában) Nem ellenörzött kivételek (Unchecked
RészletesebbenA J2EE fejlesztési si platform (application. model) 1.4 platform. Ficsor Lajos Általános Informatikai Tanszék Miskolci Egyetem
A J2EE fejlesztési si platform (application model) 1.4 platform Ficsor Lajos Általános Informatikai Tanszék Miskolci Egyetem Utolsó módosítás: 2007. 11.13. A J2EE application model A Java szabványok -
RészletesebbenEseménykezelés. Szoftvertervezés és -fejlesztés II. előadás. Szénási Sándor.
Eseménykezelés előadás http://nik.uni-obuda.hu/sztf2 Szénási Sándor szenasi.sandor@nik.uni-obuda.hu Óbudai Egyetem,Neumann János Informatikai Kar Függvénymutatókkal Származtatással Interfészekkel Egyéb
RészletesebbenJava VI. Egy kis kitérő: az UML. Osztály diagram. Általános Informatikai Tanszék Utolsó módosítás: 2006. 03. 07.
Java VI. Öröklődés Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2006. 03. 07. Java VI.: Öröklődés JAVA6 / 1 Egy kis kitérő: az UML UML: Unified Modelling Language Grafikus eszköz objektum
RészletesebbenObjektumorientált szoftvertervezés
Objektumorientált szoftvertervezés Elosztott OO, RMI, CORBA BME IIT, Goldschmidt Balázs Hálózati forgalom TCP/IP socket használatával bedrótozott protokoll alacsonyszintű adatkezelés lábbalhajtós small
RészletesebbenObjektumorientált szoftvertervezés
Hálózati forgalom Objektumorientált szoftvertervezés Elosztott OO, RMI, CORBA TCP/IP socket használatával bedrótozott protokoll alacsonyszintű adatkezelés lábbalhajtós small footprint Keretrendszerrel
RészletesebbenProgramozási nyelvek Java
statikus programszerkezet Programozási nyelvek Java Kozsik Tamás előadása alapján Készítette: Nagy Krisztián 2. előadás csomag könyvtárak könyvtárak forrásfájlok bájtkódok (.java) (.class) primitív osztály
RészletesebbenTartalom DCOM. Történeti áttekintés. Történeti áttekintés. Történeti áttekintés. Történeti áttekintés
Tartalom D Szoftvertechnológia elıadás Architektúra D vs CORBA Példá 2 1987 Dynamic Data Exchange (DDE) Windows 2.0-ban Windows alkalmazások közötti adatcsere Ma is használatos (pl. vágólap) NetDDE NetBIOS
RészletesebbenObjektumorientált szoftvertervezés
Objektumorientált szoftvertervezés Elosztott OO, RMI, CORBA BME IIT, Goldschmidt Balázs Hálózati forgalom TCP/IP socket használatával bedrótozott protokoll alacsonyszintű adatkezelés lábbalhajtós small
RészletesebbenHelyes-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?
A "java Villa -v" parancs jelentése: A java interpreter elindítja a Villa osztály statikus main metódusát, és átadja neki paraméterként a "-v" stringet. A java interpreter elindítja először a Villa osztály
RészletesebbenJava IX. telkezelés a Java-ban
Java IX. Kivétel telkezelés a Java-ban Krizsán Zoltán Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2005. 11. 17. Java IX. Kivételkezelés JAVA9 / 1 A kivételkezel telkezelés célja Kivételes
RészletesebbenKivételkezelés, beágyazott osztályok. Nyolcadik gyakorlat
Kivételkezelés, beágyazott osztályok Nyolcadik gyakorlat Kivételkezelés Nem minden hibát lehet fordítási időben megtalálni Korábban (pl. C-ben) a hibakezelést úgy oldották meg, hogy a függvény hibakódot
RészletesebbenSe S r e ial a iza z t a ion o n (in n Ja J v a a v ) a Szerializáció
Serialization (in Java) Szerializáció Java Serialization API Standard eljárás az objektumok állapotának adatfolyamba történő kiírására (elmentésére egy bájtszekvenciába), és visszatöltésére Perzisztencia
RészletesebbenJava IX. telkezelés a Java-ban
Java IX. Kivétel telkezelés a Java-ban Krizsán Zoltán Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2005. 11. 17. Java IX. Kivételkezelés JAVA9 / 1 A kivételkezel telkezelés célja Kivételes
RészletesebbenPHP II. WEB technológiák. Tóth Zsolt. Miskolci Egyetem. Tóth Zsolt (Miskolci Egyetem) PHP II. 2014 1 / 19
PHP II. WEB technológiák Tóth Zsolt Miskolci Egyetem 2014 Tóth Zsolt (Miskolci Egyetem) PHP II. 2014 1 / 19 Tartalomjegyzék Objektum Orientált Programozás 1 Objektum Orientált Programozás Öröklődés 2 Fájlkezelés
RészletesebbenOsztályok. 4. gyakorlat
Osztályok 4. gyakorlat Az osztály fogalma Az objektumok formai leírása, melyek azonos tulajdonsággal és operációkkal rendelkeznek. Osztályból objektum készítését példányosításnak nevezzük. Minden objektum
RészletesebbenJava és web programozás
Budapesti Műszaki Egyetem 2015. 04. 08. 9. Előadás Kivétel kezelés a kivétel (exception) egy esemény, mely futás közben megbontja a program normális futási folyamatát például kivétel dobódik amikor 0-val
RészletesebbenOsztott rendszerek (Distributed. systems) Bevezetés. Tartalom. Ficsor Lajos. Miskolci Egyetem Általános Informatikai Tanszék
Osztott rendszerek (Distributed systems) Bevezetés Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2007. 09. 18. osztottrendszerek / 1 Tartalom Miért kellenek osztott rendszerek Egy kis
RészletesebbenMár megismert fogalmak áttekintése
Interfészek szenasi.sandor@nik.bmf.hu PPT 2007/2008 tavasz http://nik.bmf.hu/ppt 1 Témakörök Polimorfizmus áttekintése Interfészek Interfészek kiterjesztése Eseménykezelési módszerek 2 Már megismert fogalmak
RészletesebbenKivételkezelés a C++ nyelvben Bevezetés
Kivételkezelés a C++ nyelvben Bevezetés Miskolci Egyetem Általános Informatikai Tanszék Kivételkezelés a C++ nyelvben CPP9 / 1 Hagyományos hibakezelés Függvény visszatérési értéke (paramétere) hátrányai:
RészletesebbenSzéchenyi István Egyetem. Programozás III. Varjasi Norbert varjasin@sze.hu
Programozás III. Varjasi Norbert varjasin@sze.hu 1 A java virtuális gép (JVM) Képzeletbei, ideális számítógép. Szoftveresen megvalósított működési környezet. (az op. rendszer egy folyamata). Feladata:
RészletesebbenVé V g é r g e r h e a h j a tá t s á i s s z s ál á ak a Runnable, Thread
Végrehajtási szálak Runnable, Thread Végrehajtási szálak Java-ban A Java program az operációs rendszer egy folyamatán (process) belül fut. A folyamat adat és kód szegmensekből áll, amelyek egy virtuális
RészletesebbenList<String> l1 = new ArrayList<String>(); List<Object> l2 = l1; // error
Generics Egyszerűbb példák (java.util csomagból): public interface List { void add(e x); Iterator iterator(); public interface Iterator { E next(); boolean hasnext(); E - formális típusparaméter,
RészletesebbenOOP és UML Áttekintés
OOP és UML Áttekintés Tóth Zsolt Miskolci Egyetem 2013 Tóth Zsolt (Miskolci Egyetem) OOP és UML Áttekintés 2013 1 / 32 Tartalom jegyzék 1 OOP Osztály Öröklődés Interfész, Absztrakt Osztály Kivétel kezelés
RészletesebbenSerialization. RMI működése
RMI Az RMI (Remote Method Invocation), azaz távoli metódushívás egy olyan eszköz a Java nyelvben, mely lehetővé teszi más VM-ben (Virtual Machine virtuális gép) elhelyezkedő objektumok metódusainak meghívását.
RészletesebbenA Java EE 5 plattform
A Java EE 5 platform Ficsor Lajos Általános Informatikai Tanszék Miskolci Egyetem Utolsó módosítás: 2007. 11. 13. A Java EE 5 platform A Java EE 5 plattform A J2EE 1.4 után következő verzió. Alapvető továbbfejlesztési
RészletesebbenOsztott rendszerek (Distributed
Osztott rendszerek (Distributed systems) Bevezetés Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2007. 09. 18. osztottrendszerek / 1 Tartalom Miért kellenek osztott rendszerek Egy kis
RészletesebbenObjektum Orientált Programozás. 11. Kivételkezelés 44/1B IT MAN
Objektum Orientált Programozás 11. Kivételkezelés 44/1B IT MAN B IT v: 2016.05.03 MAN Pici elmélet A Java kivételkezelésének célja a programfutás során keletkezett hibák kiszűrése és megfelelő kezelése.
RészletesebbenStatikus adattagok. Statikus adattag inicializálása. Speciális adattagok és tagfüggvények. Általános Informatikai Tanszék
Speciális adattagok és tagfüek Miskolci Egyetem Általános Informatikai Tanszék CPP7 / 1 Statikus adattagok Bármely adattag lehet static tárolási osztályú A statikus adattag az osztály valamennyi objektuma
RészletesebbenKommunikáció. 3. előadás
Kommunikáció 3. előadás Kommunikáció A és B folyamatnak meg kell egyeznie a bitek jelentésében Szabályok protokollok ISO OSI Többrétegű protokollok előnyei Kapcsolat-orientált / kapcsolat nélküli Protokollrétegek
RészletesebbenBevezető. Servlet alapgondolatok
A Java servlet technológia Fabók Zsolt Ficsor Lajos Általános Informatikai Tanszék Miskolci Egyetem Utolsó módosítás: 2008. 03. 06. Servlet Bevezető Igény a dinamikus WEB tartalmakra Előzmény: CGI Sokáig
RészletesebbenCREATE TABLE student ( id int NOT NULL GENERATED ALWAYS AS IDENTITY PRIMARY KEY, name varchar(100) NOT NULL, address varchar(100) NOT NULL )
Célok: a Java DB adatbázis-kezelő rendszer használatának ismertetése, adatbázisok használata Java alkalmazásokban - kétrétegű architektúra, egyszerű kliens-szerver architektúra használata hálózati alkalmazásokhoz.
RészletesebbenFicsor Lajos Általános Informatikai Tanszék Miskolci Egyetem
A Java EE 5 platform Ficsor Lajos Általános Informatikai Tanszék Miskolci Egyetem Utolsó módosítás: 2008. 04. 17. A Java EE 5 platform A Java EE 5 plattform A J2EE 1.4 után következő verzió. Alapvető továbbfejlesztési
RészletesebbenJava és web programozás
Budapesti Műszaki Egyetem 2015. 02. 11. 2. Előadás Mese Néhány programozási módszer: Idők kezdetén való programozás Struktúrált Moduláris Funkcionális Objektum-orientált... Mese Néhány programozási módszer:
RészletesebbenJava bevezet o Kab odi L aszl o Kab odi L aszl o Java bevezet o
Miért Java? széleskörben elterjedt Micro Edition - beágyazott rendszerek, régi telefonok Standard Edition - PC, android ezen alapul Enterprise Edition - vállalati programok, web service-ek multiplatform
RészletesebbenJava programozási nyelv 4. rész Osztályok II.
Java programozási nyelv 4. rész Osztályok II. Nyugat-Magyarországi Egyetem Faipari Mérnöki Kar Informatikai Intézet Soós Sándor 2005. szeptember A Java programozási nyelv Soós Sándor 1/17 Tartalomjegyzék
RészletesebbenOsztályok. construct () destruct() $b=new Book(); $b=null; unset ($b); book.php: <?php class Book { private $isbn; public $title;
PHP5 objektumok 1 Osztályok class, new book.php: construct () destruct() $b=new Book(); törlés: $b=null; vagy unset ($b); -elnevezési konvenciók private $isbn; public $title; function
RészletesebbenJava programozási nyelv 5. rész Osztályok III.
Java programozási nyelv 5. rész Osztályok III. Nyugat-Magyarországi Egyetem Faipari Mérnöki Kar Informatikai Intézet Soós Sándor 2005. szeptember A Java programozási nyelv Soós Sándor 1/20 Tartalomjegyzék
RészletesebbenProgramozási nyelvek II. JAVA EA+GY 1. gyakolat
Programozási nyelvek II. JAVA EA+GY 1. gyakolat EÖTVÖS LORÁND TUDOMÁNYEGYTEM INFORMATIKAI KAR PROGRAMOZÁSI NYELVEK ÉS FORDÍTÓPROGRAMOK TANSZÉK 2017/2018. őszi félév Tartalom 1 Amit tudni kell a félévről
RészletesebbenSzoftvertechnológia alapjai Java előadások
Szoftvertechnológia alapjai Java előadások Förhécz András, doktorandusz e-mail: fandrew@mit.bme.hu tárgy honlap: http://home.mit.bme.hu/~fandrew/szofttech_hu.html 1 Kivételkezelés I. szokatlan, váratlan
RészletesebbenOsztott rendszerek. Krizsán Zoltán 1 Ficsór Lajos 1. Webalkalmazások fejlesztése tananyag. Miskolci Egyetem. Bevezetés A múlt - történelem A jelen
Osztott rendszerek Krizsán Zoltán 1 Ficsór Lajos 1 1 Általános Informatikai Tanszék Miskolci Egyetem Webalkalmazások fejlesztése tananyag Tartalom Bevezetés A múlt - történelem A jelen Denition Distributed
RészletesebbenJava V. Osztályszint. lyszintű ű tagok. Példányváltozó. Osztályváltozó. Általános Informatikai Tanszék Utolsó módosítás:
Java V. szint lyszintű ű tagok A final minősítő Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2005. 10. 05. Java V.: szintű tagok JAVA5 / 1 Példányváltozó Az eddig megismert adattagokból
RészletesebbenTartalom. Történeti áttekintés. Történeti áttekintés 2011.03.23. Architektúra DCOM vs CORBA. Szoftvertechnológia
Tartalom D Szoftvertechnológia előadás Történeti áttekintés Architektúra D vs CORBA 2 Történeti áttekintés 1987 Dynamic Data Exchange (DDE) Windows 2.0-ban Windows alkalmazások közötti adatcsere Ma is
RészletesebbenProgramozási nyelvek II.: JAVA
Programozási nyelvek II.: JAVA 13. gyakorlat 2017. december 11-15. 13. gyakorlat Programozási nyelvek II.: JAVA 1 / 32 Az 13. gyakorlat tematikája Generikus típusokés öröklődés Clone Comparator Névtelen
RészletesebbenBevezetés a Java programozási nyelvbe
Bevezetés a Java programozási nyelvbe Miskolci Egyetem Általános Informatikai Tanszék Bevezetés a Java programozási nyelvbe JAVABEV / 1 Egy kis történelem 1. 1990-es évek eleje: a SUN belső project-je
RészletesebbenAdatbázis alapú rendszerek gyakorlat Adatbázis alapú alkalmazásfejlesztés Java, C# környezetben
Adatbázis alapú rendszerek gyakorlat Adatbázis alapú alkalmazásfejlesztés Java, C# környezetben Java GUI készítése, Oracle kapcsolódás JDBC-vel A jelen anyagban egy egyszerűsített megközelítéssel vizsgáljuk
RészletesebbenKomponens alapú programozás Bevezetés
Komponens alapú programozás Bevezetés Ficsor Lajos Miskolci Egyetem Általános Informatikai Tanszék Ez a tananyag felhasználja a TEMPUS S_JEP-12495-97 Network Computing Chapter 8 Developing of Network Computing
RészletesebbenProgramozási nyelvek Java
Programozási nyelvek Java Kozsik Tamás előadása alapján Készítette: Nagy Krisztián 8. előadás Öröklődés - megnyitunk egy osztályt egy másik előtt zárt egységeket szeretünk készíteni (láthatósági kérdés:
RészletesebbenJava VI. Miskolci Egyetem Általános Informatikai Tanszék. Utolsó módosítás: Ficsor Lajos. Java VI.: Öröklődés JAVA6 / 1
Java VI. Öröklődés Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2006. 03. 07. Java VI.: Öröklődés JAVA6 / 1 Egy kis kitérő: az UML UML: Unified Modelling Language Grafikus eszköz objektum
RészletesebbenProgramozás I. 5. gyakorlat. Szegedi Tudományegyetem Természettudományi és Informatikai Kar
Programozás I. 5. gyakorlat 1 Objektumorientáltság Egységbezárás és információ elrejtése (absztrakt adattípus) Adatok és rajtuk végzett műveletek egységbezárása (osztályok írása, múlt hét) Öröklődés Polimorfizmus
RészletesebbenOBJEKTUM ORIENTÁLT PROGRAMOZÁS JAVA NYELVEN. vizsgatételek
OBJEKTUM ORIENTÁLT PROGRAMOZÁS JAVA NYELVEN vizsgatételek 1. Az objektumorientált programozás szemlélete, az objektum fogalma 2. Az objektumorientált programozás alapelvei 3. A Java nyelv története, alapvető
RészletesebbenElosztott rendszerek: Alapelvek és paradigmák Distributed Systems: Principles and Paradigms
Elosztott rendszerek: Alapelvek és paradigmák Distributed Systems: Principles and Paradigms Maarten van Steen 1 Kitlei Róbert 2 1 VU Amsterdam, Dept. Computer Science 2 ELTE Informatikai Kar 10. rész:
RészletesebbenÁttekintés. Tartalom. Mi is az a Bean?
A JavaBeans komponens modell Áttekintés Ficsor Lajos Miskolci Egyetem Általános Informatikai Tanszék Ez a tananyag felhasználja a TEMPUS S_JEP-12495-97 Network Computing Chapter 8 Developing of Network
RészletesebbenFicsor Lajos Miskolci Egyetem Általános Informatikai Tanszék
A JavaBeans komponens modell Áttekintés Ficsor Lajos Miskolci Egyetem Általános Informatikai Tanszék Ez a tananyag felhasználja a TEMPUS S_JEP-12495-97 Network Computing Chapter 8 Developing of Network
RészletesebbenRMI. Az alapoktól a részletekig RMI, activation, class loader-ek, serialization
RMI Az alapoktól a részletekig RMI, activation, class loader-ek, serialization Tartalomjegyzék BEVEZETÉS... 1 Mi az az RMI?... 1 Mi kell a dokumentum használatához?... 1 A dokumentum felépítése, használata...
RészletesebbenXML adatkezelés I. Az SAX szabvány. Dr. Kovács László Miskolci Egyetem Általános Informatikai Tanszék. XML adatok kezelési lehetőségei
XML adatkezelés I. Az szabvány Dr. Kovács László Miskolci Egyetem Általános Informatikai Tanszék XML adatok kezelési lehetőségei szövegszerkesztő API XML DOM API XSL XQUERY Az XML dokumentumok feldolgozó
RészletesebbenJava. Java Message Service. ANTAL Margit. JMS API technológia. ANTAL Margit. Sapientia - EMTE
Sapientia - EMTE 2008 Az előadás célja Üzenetkommunikációs architektúrák JMS Példák Üzenet gyártó Szinkron üzenetfogyasztó Aszinkron üzenetfogyasztó Üzenetbab (message-driven bean) point-to-point modell:
RészletesebbenMi a különbség az extends és az implements között. Mikor melyiket kell használni? Comperable-t megvalósító oasztályokban össze lehet hasonlitani
Mi a legabsztraktabb típus a JAVA-ban? Object Mikor preferált interface-ek használata a konkrét típusok helyett? Ha egy osztály több interfacet is használhasson, vagy ha fvek implementálását a az osztályra
RészletesebbenCORBA bevezetés. Paller Gábor 2004.10.08. Internet és mobil rendszerek menedzselése
CORBA bevezetés Paller Gábor 2004.10.08 CORBA Common Object Request Broker Architecture Az Object Management Group (OMG) felügyeli (ugyanaz, mint az UML-t) A specifikáció célja alkalmazások együttműködésének
RészletesebbenHálózatkezelés. Tóth Zsolt. Miskolci Egyetem. Tóth Zsolt (Miskolci Egyetem) Hálózatkezelés / 20
Hálózatkezelés Tóth Zsolt Miskolci Egyetem 2013 Tóth Zsolt (Miskolci Egyetem) Hálózatkezelés 2013 1 / 20 Tartalomjegyzék 1 Hálózati Alapismeretek 2 System.Net Namespace 3 Socket Kezelés 4 Példa Tóth Zsolt
RészletesebbenKivételek kezelése (exception handling) Hibakezelés old style. Kivételkezelés
Kivételek kezelése (exception handling) Hibakezelés old style class Szamolo { void szamol( String s, int i ) { int d; if (i!= 0) d = (i+1)/i; else if (s!= null) d = s.length(); else if (i > 10) // applikációs
RészletesebbenKommunikáció. Távoli eljáráshívás. RPC kommunikáció menete DCE RPC (1) RPC - paraméterátadás. 3. előadás Protokollok. 2. rész
3. előadás Protokollok Kommunikáció 2. rész RPC (Remote Procedure Call) távoli eljáráshívás RMI (Remote Method Invocation) távoli metódushívás MOM (Message-Oriented Middleware) üzenetorientált köztesréteg
RészletesebbenJava programozási nyelv
Szoftvertechnológia sáv Java programozási nyelv Dirk Louis-Peter Müller: Java (Belépés az internet világába) Panem kiadó, Budapest, 2002. Webvilág sorozat Készítette: Gregorics Tibor Vázlatos áttekintés
RészletesebbenProgramozási nyelvek Java
Programozási nyelvek Java Kozsik Tamás előadása alapján Készítette: Nagy Krisztián 9. előadás Interface - típust vezet be, de osztálypéldány nem készíthető belőle (statikus típust ad) - több osztály is
RészletesebbenKivételkezelés, naplózás. Exception handling, logging
Kivételkezelés, naplózás Exception handling, logging Try-catch try { // Kódrészlet, amely kivételt eredményezhet catch (Exception1 object1 ) { // Az Exception1 kivétel kezelésének megfelelő kód catch (Exception2
RészletesebbenOOP: Java 8.Gy: Gyakorlás
OOP: Java 8.Gy: Gyakorlás 43/1 B ITv: MAN 2019.04.10 43/2 Egy régebbi beszámoló anyaga 1. Feladat: Készítsen egy Szemely nevű osztályt a szokásos konvenciók betartásával, amely tárolja egy ember nevét
RészletesebbenJAVA PROGRAMOZÁS 3.ELŐADÁS
Dr. Pál László, Sapientia EMTE, Csíkszereda JAVA PROGRAMOZÁS 3.ELŐADÁS 2014-2015 tavasz Polimorfizmus, absztrakt osztályok, interfészek 2 Példa - Hengerprogram 3 Példa - Hengerprogram 4 Példa - Hengerprogram
RészletesebbenBME MOGI Gépészeti informatika 8.
BME MOGI Gépészeti informatika 8. 1. feladat Készítse beosztottak és vezetők munkahelyi adatait kezelő alkalmazást! A feladat megoldásához hozza létre a következő osztályokat! Beosztott osztály: adatmező
RészletesebbenCORBA. Mi a CORBA? A CORBA felépítése
Mi a CORBA? CORBA A programok által használt objektumok nem szükségképpen korlátozódnak az operációs rendszer által a programok számára kijelölt memóriaterületre - a program címzési tartományára. Általánosabb
RészletesebbenJAVA webes alkalmazások
JAVA webes alkalmazások Java Enterprise Edition a JEE-t egy specifikáció definiálja, ami de facto szabványnak tekinthető, egy ennek megfelelő Java EE alkalmazásszerver kezeli a telepített komponensek tranzakcióit,
RészletesebbenS04-2 Elosztott alkalmazások készítése
S04-2 Elosztott alkalmazások készítése Tartalom 1. Többrétegű architektúra, elosztott szerveroldal 2. Kommunikációs eszközök: távolieljárás-hívás és üzenet alapú infrastruktúra (point-to-point és publish-subscribe
RészletesebbenA SZOFTVERTECHNOLÓGIA ALAPJAI
A SZOFTVERTECHNOLÓGIA ALAPJAI Objektumorientált tervezés 8.előadás PPKE-ITK Tartalom 8.1 Objektumok és objektumosztályok 8.2 Objektumorientált tervezési folyamat 8.2.1 Rendszerkörnyezet, használati esetek
RészletesebbenSmalltalk 3. Osztályok létrehozása. Készítette: Szabó Éva
Smalltalk 3. Osztályok létrehozása Készítette: Szabó Éva Metaosztály fogalma Mint korában említettük, a Smalltalkban mindent objektumnak tekintünk. Még az osztályok is objektumok. De ha az osztály objektum,
RészletesebbenA Jáva programozási nyelv rejtelmei
Page 1 of 20 A Jáva programozási nyelv rejtelmei Tartalomjegyzék: Az alapok Egy példaprogram A program szerkezete Változók és értékek Megjegyzések a programban A fôprogram Vezérlési szerkezetek Kivételkezelés
RészletesebbenJava és web programozás
Budapesti M szaki Egyetem 2013. szeptember 18. 2. El adás Komplex szám public class Complex { private float repart_; private float impart_; public Complex() { repart_ = 0; impart_ = 0; public Complex(float
RészletesebbenCO C R O B R A B OMG, ORB, CORBA
CORBA OMG, ORB, CORBA OMG CORBA (Common Object Request Broker Architecture) az OMG (Object Management Group) által definiált standard, ami lehetővé teszi különböző nyelveken írt, különböző számítógépeken
Részletesebben