A számítógépes programozásban az eseményvezérelt programozás egy programozási paradigma, amiben a program futását az események határozzák meg, mint például a felhasználói műveletek (egérkattintás, billentyűleütés), az érzékelők kimenetei vagy más programok vagy szálak által küldött üzenetek. Az eseményvezérelt programozás a grafikus felhasználói felületek és más olyan alkalmazások (pl. JavaScript webes alkalmazások) domináns paradigmája, amelyek középpontjában a felhasználói bemenetre reagálva bizonyos műveletek végrehajtása áll. Szintén ez igaz az eszközillesztő programok programozására is. (Például a P az USB eszközillesztő csomagokban.[1])
Az eseményvezérelt programozásban általában van egy fő ciklus, ami figyeli az eseményeket, majd kivált egy visszahívási függvényt, amikor az események valamelyikét észleli. Beágyazott rendszerekben ugyanezt hardveres megszakításokkal lehet elérni a folyamatosan futó fő ciklus helyett. Az eseményvezérelt programokat bármilyen nyelven meg lehet írni, bár a feladat könnyebb olyan nyelveken, amelyek magas szintű absztrakciókat biztosítanak, mint például az await és a closure.
Eseménykezelők
Egy triviális eseménykezelő
Mivel az események ellenőrzésére szolgáló kód és a fő ciklus az alkalmazások között közös, ennek ellenére sok programozási keretrendszer gondoskodik ezek megvalósításáról és elvárja, hogy a felhasználó csak az eseménykezelők kódját adja meg. Ebben az egyszerű példában lehet egy OneKeyEnter() nevű eseménykezelő hívása, ami egy karakterláncot tartalmazó argumentumot tartalmaz, ami megfelel annak, amit a felhasználó az ENTER billentyű lenyomása előtt beírt. Két szám hozzáadásához az eseménykezelőn kívüli tárolást kell használni. Ez az implementáció az alábbiak szerint nézhet ki.
Globálisan deklaráljuk a K számlálót és a T egész számot
OneKeyEnter (karakter C) {
C átalakítása N számmá
ha K nulla, tároljuk N-t T-ben és növeljük a K-t
ellenkező esetben adjuk hozzá N-t T-hez
írassuk ki az eredményt, majd a K-t állítsuk vissza nullára
}
Az előzmények nyomon követése triviális egy szekvenciális programban, mivel az eseménykezelők külső eseményekre válaszolva hajtódnak végre, az eseménykezelők megfelelő strukturálása, hogy bármilyen sorrendben történő hívás esetén helyesen működjenek, különleges figyelmet és tervezést igényel egy eseményvezérelt programozásban.
Eseménykezelők létrehozása
Az eseményvezérelt program fejlesztésének első lépése az eseménykezelő rutinoknak nevezett alprogramok vagy metódusok írása. Ezek a rutinok kezelik azokat az eseményeket, amelyekre a főprogram reagálni fog. Például egy GUI-programban a bal egérgombbal egy parancsgombra történő egyetlen kattintás kiválthat egy olyan rutint, amely megnyit egy másik ablakot, adatokat ment egy adatbázisba vagy kilép az alkalmazásból. Számos modern programozási környezet eseménysablonokat biztosít a programozó számára, így a programozó az eseménykód megírására fókuszálhat.
A második lépés az eseménykezelők eseményhez kötése, hogy az esemény bekövetkezésekor a megfelelő funkciót hívja meg a rendszer. A grafikus szerkesztők kombinálják az első két lépést: kattints duplán egy gombra, és a szerkesztő létrehoz egy (üres) eseménykezelőt, amely a felhasználó gombra kattintásához kapcsolódik, majd megnyit egy szövegablakot, hogy szerkeszthesse az eseménykezelőt.
Az eseményvezérelt program fejlesztésének harmadik lépése a fő ciklus megírása. Ez egy olyan függvény, ami ellenőrzi az események bekövetkezését, majd meghívja a megfelelő eseménykezelőt, hogy feldolgozza azt. A legtöbb eseményvezérelt programozási környezet már biztosítja ezt a fő ciklust, így az alkalmazás programozójának nem kell külön gondoskodnia róla. Az RPG az IBM korai programozási nyelve, amelynek az 1960-as évek tervezési koncepciója hasonló volt a fent tárgyalt eseményvezérelt programozáshoz, egy beépített fő I/O-ciklus (úgynevezett "programciklus") biztosított, ahol a számítások a ciklusban korábban beállított "indikátoroknak" (zászlóknak) megfelelően reagáltak
Kivételkezelők a PL/I-ben
A PL/I-ben, még ha a program nem is túlnyomórészt eseményvezérelt, előfordulhatnak bizonyos rendellenes események, mint például hardverhiba, túlcsordulás vagy "programellenőrzés", amelyek esetleg megakadályozzák a további feldolgozást. A kivételkezelőket "ON utasítások" biztosítják a (nem látható) hívókban, hogy tisztító rutinokat biztosítsanak az utólagos tisztításhoz a befejezés előtt, vagy hogy helyreállítási műveleteket végezzenek és visszatérjenek a megszakított eljáráshoz.
Általános felhasználások
A legtöbb létező GUI-fejlesztő eszköz és architektúra az eseményvezérelt programozásra támaszkodik.[2] A Java AWT keretrendszer minden UI-változást egyetlen szálon, az úgynevezett eseménykiosztó szálon dolgoz fel. Hasonlóképpen, a Java keretrendszer JavaFX-ben minden UI-frissítés a JavaFX Application Thread-en történik.[3]
Emellett az olyan rendszerek, mint a Node.js is eseményvezéreltek.[4]
Kritika
Az esemény-akció modellre támaszkodó programok tervezését kritikával illetik, és azt állítják, hogy az esemény-akció modell hibaérzékeny, nehezen bővíthető és túlságosan összetett alkalmazási kód létrehozására készteti a programozókat. A táblázatvezérelt állapotgépeket életképes alternatívaként támogatják.[5] Másrészt a táblázatvezérelt állapotgépek maguk is jelentős gyengeségekkel küzdenek, beleértve az állapotrobbanás jelenségét.[6] Erre megoldást jelent a Petri-hálók használata.
Verem nélküli környezet
A hardveres leíró nyelvekben eseményvezérelt megközelítést alkalmaznak. Egy környezetnek csak akkor van szüksége a CPU veremre, amikor aktívan feldolgoz egy eseményt, majd, ha ezzel végzett, a CPU továbbléphet más eseményvezérelt szálak feldolgozására. Ez rendkívül nagy számú szál kezelését teszi lehetővé. Ez lényegében egy véges állapotú gépi megközelítés.
Jegyzetek
Fordítás
Ez a szócikk részben vagy egészben az Event-driven programming című angol Wikipédia-szócikk ezen változatának fordításán alapul. Az eredeti cikk szerkesztőit annak laptörténete sorolja fel. Ez a jelzés csupán a megfogalmazás eredetét és a szerzői jogokat jelzi, nem szolgál a cikkben szereplő információk forrásmegjelöléseként.
Kapcsolódó szócikkek
- Párhuzamossági minták bemutatása a scaleconf-on
- Eseményvezérelt programozás: Bevezetés, bemutató, előzmények, Stephen Ferg oktatóprogramja
- Eseményvezérelt programozás, oktatóanyag: Alan Gauld
- Esemény együttműködés, Martin Fowler cikke
- Átgondolva a Swing Threading-t, Jonathan Simon cikke
- Az eseményvezérelt programozási stílus Archiválva 2005. február 20-i dátummal a Wayback Machine-ben. , Chris McDonald cikke
- Eseményvezérelt programozás a sablonspecializáció segítségével, Christopher Diggins cikke
- Schiffer, S.. Concepts and architecture of Vista-a multiparadigm programming environment, Proceedings of 1994 IEEE Symposium on Visual Languages, 40–47. o.. DOI: 10.1109/VL.1994.363642 (1994). ISBN 0-8186-6660-9 0-8186-6660-9
- Eseményvezérelt programozás és ügynökök, fejezet
- LabWindows / CVI erőforrások
- Distributed Publish / Subscribe Event System, egy nyílt forráskódú példa, amely az MSN.com és a Microsoft.com webhelyeken készül
- Javascript Esemény hurok