A belsőplatform-hatás az a tendencia, amikor a programozók lemásolják az általuk használt keretrendszer konfigurálhatóságát, így a program a keretrendszer szegényes másolata lesz. Ez általában nem hatékony, és William J. Brown antimintának tekinti.
Példák
Szövegszerkesztők és webböngészők képességei bővíthetők pluginok hozzáadásával. A pluginok fejlesztői gyakran kénytelenek újraalkotni egy olyan programot, ami az operációs rendszer felső szintjén fut. A Firefox kiegészítő mechanizmusát használták arra, hogy több FTP-klienst és -fájlkezelőt hozzanak létre, amellyel hatékonyan másolja az operációs rendszer képességeit egy korlátozottabb platformon.
Az adatbázisok világában gyakran megkerülik az RDBMS-t, például mindent egy nagy táblában tárolnak, aminek három oszlopa az entitás azonosítója, kulcsa és értéke. Míg ez az entitás-attributum-érték modell lehetővé teszi a kitörést az SQL korlátai közül, addig ezzel elvész az adatbázis használatának összes előnye.[1] Ennek az az oka, hogy most már ahelyett, hogy az RDBMS hatékonyan el tudná végezni a szükséges műveleteket, külső alkalmazásokra van szükség. Bonyolultabbá válnak a lekérdezések,[2] az indexek és a lekérdezésoptimalizálók hatékonyságukat vesztik, és az adatok érvényességi megkötései nem ellenőrizhetők. A program lassúvá és nehezen karbantarthatóvá válik.
Hasonlóval próbálkoznak XML-ben is. Az információt attributumokban tárolják, az elemek nevét pedig semmitmondónak adják meg. Például az elem neve item, type és value attributumokkal. A jelentés kivonatolására join műveletekre van szükség, több attributumon keresztül. Mivel a join egy kevéssé hatékony művelet, az XPath lekérdezések is kevéssé hatékonyak lesznek, amellett, hogy bonyolódnak is. A szerkezeti érvényesség vizsgálata kevés előnnyel jár.
Egy további példa a web desktop, ahol egy teljes ablakozó rendszert kapunk, ami webböngészőben fut (ami az operációs rendszer által nyújtott felületen fut), és rajta is futhat webböngésző. A web desktop szokatlanul kényelmetlen lehet a felhasználóknak (felület felületen belül), így általában csak arra használják, hogy olyan programokat futtasson, amelyek nem deployolhatók közvetlenül az operációs rendszerre vagy kitakarják a teljes felületet.
Hatása
Teljesen normális, ha olyan könyvtárat hoznak létre, ami támogatja a specifikus projektet. Belsőplatform-hatásról akkor beszélnek, ha általános célú függvényeket valósítanak meg újra, amely függvények már megvannak a nyelvben vagy a keretrendszerben. Mivel ezek a platform több függvényét hívják meg, lassabbak, és többnyire kevésbé megbízhatók.
Másrészt ezeket a függvényeket gyakran azért hozzák létre, hogy egyszerűbb, hordozható platformot alkossanak szemben az alatta levő nem hordozható, sokkal összetettebb, túl bonyolult interfészű réteg fölé.
A belső platformkód megalkotása hasznos lehet a hordozhatóság vagy a jogok elkülönült kezelésének érdekében, így amit ezzel készítenek, annak nem kell törődnie az alsó szintekkel, sem pedig a dobozon kívüli jogi környezettel. Így tervezte például a Sun Microsystems a Java virtuális gépet.
Jegyzetek
Források
Fordítás
Ez a szócikk részben vagy egészben az Inner-platform effect című angol Wikipédia-szócikk 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.