A rekord mezők gyűjteménye, amelyek lehetnek különböző adattípusúak, általában fix számúak és sorrendben vannak elhelyezve.[5] A rekord mezőit néha tagoknak is nevezik, különösen objektumorientált programozásban. A mezőket elemeknek is nevezhetjük, bár ez összetévesztheti a gyűjtemény elemeivel.
Például egy dátumot tárolhatunk egy rekordban, amely egy numerikusévszám mezőt, egy stringként ábrázolt hónapmezőt és egy numerikus hónapnap mezőt tartalmaz. Egy személyi rekord tartalmazhat nevet, fizetést és rangot. Egy kör rekord tartalmazhat egy középpontot és egy sugarat – ebben az esetben a központot maga is egy pont rekordként ábrázolhatjuk, amely tartalmazza az x és y koordinátákat.
A rekordok megkülönböztethetők a tömböktől azzal a jellemzővel, hogy mezőik száma a rekord definíciójában van meghatározva, és a rekordok egy heterogén adattípusok; nem minden mezőnek kell ugyanolyan típusú adatot tartalmaznia.[6]
A rekord típus egy olyan adattípus, amely leírja az ilyen értékeket és változókat. A legtöbb modern számítógépes nyelv lehetővé teszi a programozó számára, hogy definiáljon új rekord típusokat. A definíció magában foglalja minden mező adattípusának és azonosítójának (név vagy címke) meghatározását, amelyen keresztül hozzáférhetők. A típuselméletben általában a termék típusokat (amelyeknek nincsenek mezőneveik) részesítik előnyben egyszerűségük miatt, de a megfelelő rekord típusokat tanulmányozzák olyan nyelvekben, mint például a System F-sub. Mivel a típuselméleti rekordok adatok mellett elsőrendű funkciókkal rendelkező mezőket is tartalmazhatnak, képesek kifejezni az objektumorientált programozás számos jellemzőjét.
Rekordok létezhetnek bármely tárolóeszközön, beleértve a fő memóriát és a tömegtároló eszközöket, például a mágnesszalagokat vagy a merevlemezeket. A rekordok alapvető komponensei a legtöbb adatszerkezetnek, különösen a kapcsolt adatszerkezeteknek. Sok számítógépes fájl logikai rekordok tömbje formájában van szervezve, gyakran hatékonyabbá téve azokat a nagyobb fizikai rekordokba vagy blokkokba csoportosítással.
Egy függvény vagy eljárás paramétereit gyakran úgy lehet tekinteni, mint egy rekordváltozó mezőit; és a függvénynek átadott argumentumok tekinthetők úgynevezett rekordértéknek, amelyet a híváskor a változónak rendelnek. Ezenkívül, a gyakran használt hívások implementálásához használt hívási veremben minden bejegyzés egy aktiválási rekord vagy hívási keret, amely tartalmazza az eljárás paramétereit és helyi változóit, a visszatérési címet és egyéb belső mezőket.
Egy objektum az objektumorientált nyelvekben lényegében egy rekord, amely eljárásokat tartalmaz a rekord kezelésére; és az objektumtípusok a rekordtípusok bővítése. Valójában a legtöbb objektumorientált nyelvben a rekordok csak az objektumok speciális esetei, és egyszerű adatstruktúráknak (PODS-eknek) nevezik őket az objektumoktól megkülönböztetve, amelyek OO funkciókat használnak.
Egy rekordot tekinthetünk a számítógépes analógjának egy matematikaisor bár egy sort lehet vagy nem lehet tekinteni rekordnak, és fordítva, a konvencióktól és a konkrét programozási nyelvtől függően. Hasonlóan, egy rekord típust tekinthetünk a számítógépes nyelv analógjának két vagy több matematikai halmazDescartes-féle szorzatának, vagy az absztrakt terméktípus megvalósításának egy adott nyelvben.
Kulcsok
Egy rekordnak lehet nullánál több kulcsa. Egy kulcs kifejezést vagy értéket, illetve érték halmazt képez a rekordban. Egy elsődleges kulcs egy olyan kulcs, amely egyedülálló az összes tárolt rekordon belül; csak egy ilyen kulcs létezik.[7] Más szóval, egyetlen elsődleges kulcshoz sem lehet duplikátum. Például egy alkalmazott fájl tartalmazhat alkalmazott számot, nevet, osztályt és fizetést. Az alkalmazott szám egyedülálló lesz a szervezetben, és ez lesz az elsődleges kulcs. A tárolóeszköztől és a fájl szervezésétől függően az alkalmazott szám lehet indexelve – azaz külön fájlban is tárolódik, hogy gyorsabban lehessen keresni. Az osztály kódja nem feltétlenül egyedi; indexelve is lehet, ilyen esetben másodlagos kulcsnak vagy alternatívkulcsnak számít.[8] Ha nincs indexelve, akkor az alkalmazott fájl teljes tartalmát át kell szkennelni az összes adott osztályban dolgozó alkalmazott listázásához. A kulcsok általában úgy vannak kiválasztva, hogy minimalizálják annak a lehetőségét, hogy több érték észszerűen leképezhető legyen egy kulcsra. Például a fizetés mezőt általában nem tekintik kulcsnak, mivel sok alkalmazottnak valószínűleg ugyanaz a fizetése van. Az indexelés egy tényező, amelyet figyelembe vesznek egy fájl tervezésekor.
Történelem
A rekord fogalma különféle típusú táblázatok és könyvelőkönyvek használatáig lehet visszavezetni, amelyek az idők kezdete óta használatosak a számvitelben. A modern rekord fogalma a számítástechnikában, jól meghatározott típusú és méretű mezőkkel, már implicit módon jelen volt a 19. századi mechanikus számológépekben, mint például a Babbage 's Analitikai motor.[9][10]
Az eredeti gépi olvasható adathordozó (ellentétben a vezérléssel) a lyukkártya volt az 1890-es Egyesült Államok népszámlálásakor: minden lyukkártya egyetlen rekordot tartalmazott. Hasonlítsuk össze az 1880-as naplóbejegyzést és az 1895-ös lyukkártyát. A rekordok jól kialakultak voltak a 20. század első felében, amikor a legtöbb adatfeldolgozás lyukkártyák segítségével történt. Általában egy adatfájl rekordja egy lyukkártyára került rögzítésre, ahol meghatározott oszlopok lettek kijelölve a különböző mezőkhöz. Általában egy rekord volt a legkisebb egység, amelyet külső tárolóból be lehetett olvasni (például lyukkártyaolvasóval, szalag vagy lemez segítségével). A lyukkártya stílusú rekordok tartalma eredetileg "egység rekordoknak" nevezték el, mivel a lyukkártyáknak előre meghatározott dokumentumhosszúságuk volt.[11] Amikor az adattároló rendszerek fejlettebbé váltak a merevlemezek és mágnesszalagok használatával, a változó hosszúságú rekordok váltak az új szabvánnyá. Egy változó hosszúságú rekord olyan rekord, amelynek a mérete byte-okban körülbelül megegyezik a mezői méreteinek összegével. Ez nem volt lehetséges korábban, amíg nem találtak ki fejlettebb tároló hardvereket, mert minden lyukkártyának meg kellett felelnie előre meghatározott dokumentumhosszúságoknak, amelyeket a számítógép tudott olvasni, mivel akkoriban a kártyákat fizikailag be kellett adagolni egy gépbe.
A legtöbb gépi kód és a korai assembly nyelvek nem rendelkezett különleges szintaxissal a rekordokhoz, de a fogalom elérhető volt (és széles körben használták) indexregiszterek, közvetett címzés és önmódosító kód használatával. Néhai korai számítógépek, mint például az IBM 1620, hardveres támogatással rendelkezett a rekordok és mezők elhatárolásához, valamint különleges utasításokkal a rekordok másolásához.
A rekordok és mezők fogalma központi szerepet játszott néhány korai fájlrendezési és táblázatkezelő segédprogramban, mint például az IBM Report Program Generator (RPG).
COBOL olt az első elterjedt programozási nyelv, amely támogatta a rekord típusokat.[12] és a rekorddefiníciós lehetőségei akkoriban elég kifinomultak voltak. A nyelv lehetővé teszi a beágyazott rekordok meghatározását alfanumerikus, egész és tört mezőkkel, tetszőleges méretű és pontosságúak lehetnek, valamint olyan mezőkkel, amelyek automatikusan formázzák az értéket, amit hozzárendelünk (például pénznem jelek, tizedes pontok és számjegycsoport-elválasztók beillesztése). Minden fájlhoz egy rekordváltozó van társítva, amelybe az adatok beolvasódnak vagy kiíródnak. A COBOL továbbá biztosít egy MOVE CORRESPONDING utasítást, amely a megfelelő nevek alapján hozzárendeli két rekord megfelelő mezőit.
A numerikus számításokhoz fejlesztett korai nyelvek, mint például a a FORTRAN (FORTRAN IV -ig) és az Algol 60, nem támogatták a rekord típusokat. Azonban a későbbi verziók, mint például a FORTRAN 77 és az Algol 68 hozzáadták ezeket a lehetőségeket. Az eredeti Lisp programozási nyelv is hiányzott a rekordoktól (kivéve a beépített negatív cellát), de az S-kifejezések megfelelő helyettesítést adtak. A Pascal programozási nyelv volt az első olyan nyelv, amely teljesen integrálta a rekord típusokat más alaptípusokkal egy logikailag következetes típusrendszerbe. A PL/I programozási nyelv támogatta a COBOL-stílusú rekordokat. A C programozási nyelv eredetileg a rekord koncepciót egyfajta sablonként (struct) biztosította, amelyet egy memóriaterületre lehetett alkalmazni, nem pedig egy igazi rekord adattípusként. Ez utóbbiakat végül is biztosították(a typedef deklarációval), de a két koncepció még mindig különbözik a nyelvben. A Pascal után tervezett legtöbb nyelv (például Ada, a Modula és a Java) szintén támogatta a rekordokat.
Bár a rekordokat már nem használják olyan gyakran eredeti kontextusukban (azaz kizárólag adatok tárolására szolgáló eszközként), hatással voltak az újabb objektumorientált programozási nyelvekre és relációs adatbázis-kezelő rendszerekre. Mivel a rekordok modulárisabbá tették az adatok tárolását és kezelését, alkalmasabbak a bonyolult, valós világot reprezentáló fogalmak ábrázolására, mint az alapértelmezetten nyújtott primitív adattípusok. Ez hatással volt a későbbi nyelvekre, mint például a C++-ra, a Python -ra, a JavaScript-re és az Objective-C-re, amelyek ugyanazokat a programozók moduláris aggályait célozzák meg.[13]Ezekben a nyelvekben az objektumok lényegében rekordok, amelyekhez hozzáadódnak módszerek és öröklődés, amelyek lehetővé teszik a programozóknak az adatok viselkedésének manipulálását, nemcsak a rekord tartalmának módosítását. Sok programozó szerint a rekordok már elavultak, mivel az objektumorientált nyelvek olyan funkciókkal rendelkeznek, amelyek messze túlmutatnak a rekordok lehetőségein. Másrészt sok programozó érvel amellett, hogy a kis overhead és a rekordok használatának képessége az assembly nyelvben még mindig releváns, amikor alacsony szintű absztrakcióval programoznak. Ma a TIOBE indexen, a programozási nyelvek népszerűségét jelző mutatónál, a legnépszerűbb nyelveket valamilyen módon befolyásolta a rekordok ténye, mivel objektumorientáltak.[14]Az SQL és az Object Query Language (Objektumlekérdezési Nyelv) nevű lekérdezési nyelvek is hatást gyakoroltak a rekordok koncepciójára. Ezek a nyelvek lehetővé teszik a programozó számára, hogy adathalmazokat, amelyek lényegében rekordok, táblákban tároljanak.[15] Ezek az adatok azután lekérhetők egy elsődleges kulcs segítségével. Maguk a táblák is rekordok, amelyek tartalmazhatnak idegen kulcsot : egy olyan kulcsot, amely egy másik tábla adataira hivatkozik.
Tevékenységek
Új rekordtípus deklarációja, beleértve az egyes mezők pozícióját, típusát és (esetleg) nevét;
Változók és értékek deklarálása adott rekordtípussal;
Rekordérték felépítése adott mezőértékekből és (néha) megadott mezőnevekkel;
Néhány nyelv lehetőséget nyújthat arra, hogy felsorolja egy rekord összes mezőjét, vagy legalább a referenciaként használt mezőket. Ez a funkció szükséges bizonyos szolgáltatások, mint például a hibakeresők, szemétgyűjtők és sorosítás implementálásához. Ehhez bizonyos mértékű típuspolimorfizmusra van szükség.
Record alaktípusokkal rendelkező rendszerekben a rekord típusú értékekkel végrehajtható műveletek közé tartozhatnak:
Új mező hozzáadása rekordhoz, az új mező értékének beállítása.
Mező eltávolítása a rekordból.
Egy ilyen környezetben egy adott rekordtípus azt jelenti, hogy egy adott mezőhalmaz jelen van, de az adott típusú értékek tartalmazhatnak további mezőket is. Például egy "x", "y" és "z" mezőkkel rendelkező rekord tartozik az "x" és "y" mezőkkel rendelkező rekordok típusába, ahogy egy "x", "y" és "r" mezőkkel rendelkező rekord is. Az indoklás az, hogy egy (x, y, z) rekord átadása egy olyan függvénynek, amely egy (x, y) rekordot vár argumentumként, működnie kellene, mivel az adott függvény megtalálja az összes számára szükséges mezőt a rekordban. Számos gyakorlatban használt rekord megvalósítási mód lehetne problémás ebben a változékonyság lehetőségének biztosítása szempontjából, de ez a kérdés a rekordtípusok központi jellemzője a több elméleti kontextusban.
Hozzárendelés és összehasonlítás
A legtöbb programozási nyelv lehetővé teszi, hogy rekordok között értékadás történjen, amelyek pontosan azonos rekordtípusúak (beleértve ugyanazokat a mezőtípusokat és neveket, ugyanabban a sorrendben). Attól függően, hogy a nyelv, két különállóan definiált rekord adattípus különálló típusoknak tekinthető, még akkor is, ha pontosan azonos mezőik vannak.
Néhány programozási nyelv lehetővé teszi a rekordok közötti értékadást, amelyek mezőinek különböző nevei vannak, és a rekordon belüli mezőváltozókat a pozíciójuk alapján illeszti a megfelelő mezőértékhez; például egy valós és képzetes mezővel rendelkező komplex számot lehet hozzárendelni egy 2D pont rekordváltozóhoz, amelynek mezői X és Y. Ebben az alternatívában továbbra is elvárás, hogy a két operandusnak ugyanazok legyenek a mezőtípusainak a sorrendje. Néhány nyelv továbbá megkövetelheti, hogy a megfelelő típusok ugyanolyan méretűek és kódolással rendelkezzenek, hogy az egész rekordot egyértelműen értelmezhető bitsorként lehessen hozzárendelni. Más nyelvek rugalmasabbak lehetnek ebben a tekintetben, és csak azt követelik meg, hogy minden értékmezőt törvényesen lehessen hozzárendelni a megfelelő változómezőhöz; így például egy rövid egész mezőt hozzá lehet rendelni egy hosszú egész mezőhöz, vagy fordítva.
Más nyelvek (például a COBOL) a mezőket és értékeket a nevük alapján illesztik össze, nem pedig a pozíciójuk alapján.
Ugyanezek a lehetőségek vonatkoznak két rekordérték összehasonlítására is. Néhány nyelv lehetővé teheti a sorrend összehasonlítást ('<' és '>') is, az egyedi mezők összehasonlításán alapuló lexikografikus sorrend használatával.
A PL/I lehetővé teszi mindkét korábbi típusú értékadást, valamint struktúra-kifejezéseket is, például a = a+1; ahol "a" egy rekord vagy struktúra PL/I terminológiában.
Az Algol 68 elosztó mező választéka
Az Algol 68-ban, ha Pts rekordokból álló tömb volt, amelyek mindegyikének integer típusú X és Y mezői voltak, akkor Y of Pts kifejezéssel egy egész számokból álló tömböt lehetett létrehozni, amely tartalmazza a Pts összes elemének Y mezőjét. Ennek eredményeként a Y of Pts[3] := 7 állításai Y of Pts[3] := 7 és (Y of Pts)[3] := 7 -nek ugyanaz a hatása.
A Pascal with kijelentése
A Pascal programozási nyelvben az with R do S parancs végrehajtja az S parancssorozatot úgy, mintha az R rekord összes mezője változóként lenne deklarálva. Hasonlóan a névtérbe lépéshez egy objektumorientált nyelvben, például a C#-ban, már nem szükséges a rekord nevét előtagként használni a mezőkhöz való hozzáféréshez. Tehát ahelyett, hogy Pt.X := 5; Pt.Y := Pt.X + 3
withPtdobeginX:=5;Y:=X+3end
ezt lehet írni:
withPtdobeginX:=5;Y:=X+3end
.
Ábrázolás a memóriában
A rekordok ábrázolása a memóriában változhat a programozási nyelvek szerint. Általában a mezők egymást követő pozíciókban vannak tárolva a memóriában, ugyanabban a sorrendben, ahogy a rekord típusban deklarálva vannak. Ez azt eredményezheti, hogy két vagy több mező ugyanabba a memóriaszóba kerül tárolásra; valójában ez a tulajdonság gyakran használatos rendszermérnöki programozásban, hogy meghatározott bitekhez férjenek hozzá egy szóban. Másrészről a legtöbb fordító láthatatlan töltőmezőket is hozzáad, hogy megfeleljenek a gép által előírt igazítási korlátozásoknak – például hogy egy lebegőpontos mezőnek egyetlen szónak kell elfoglalnia.
Néhány nyelvben a rekordot egy címsorozatokból álló tömbként valósíthatják meg, amelyek a mezőkre mutatnak (és esetlegesen a nevükre és/vagy típusukra is). Az objektumok az objektumorientált nyelvekben gyakran meglehetősen bonyolult módon vannak megvalósítva, különösen azokban a nyelvekben, amelyek többszörös osztályöröklést tesznek lehetővé.
Önmeghatározó rekordok
Az önmagát definiáló rekord olyan rekordtípus, amely azonosító információkat tartalmaz a rekord típusáról és az információ helyéről a rekordon belül. Tartalmazhatja az elemek eltolásait, így az elemek bármilyen sorrendben tárolhatók vagy elhagyhatók.[16] Az önmagát definiáló rekordban tárolt információk értelmezhetők metaadataként a rekordhoz, hasonlóan ahhoz, amit egy fájlra vonatkozó UNIXmetaadataiban találnánk, amelyek tartalmazzák például a rekord létrehozási idejét és a rekord méretét byte-okban. Másik lehetőség, hogy a rekord különböző elemei tetszőleges sorrendben követik egymást, de mindegyikük tartalmaz elemazonosítót.
↑Radványi, Tibor. Database Management Systems [archivált változat]. Eszterházy Károly College, 19. o. (2014. január 17.). Hozzáférés ideje: 2018. szeptember 23. [archiválás ideje: 2018. szeptember 23.]
↑Leavens (1990. január 17.). „Reasoning about object-oriented programs that use subtypes”. Proceedings of the European Conference on Object-oriented Programming on Object-oriented Programming Systems, Languages, and Applications - OOPSLA/ECOOP '90, New York, New York, USA, 212–223. o, Kiadó: ACM Press. DOI:10.1145/97945.97970.
Ez a szócikk részben vagy egészben a Record (computer science) 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.