|
A Perl egy programozási nyelv, melyet Larry Wall tett közzé 1987. december 18-án. Stílusában és funkcionalitásában sokat merít a C, sed, awk, sh és más programozási nyelvekből. A nyelv egyik legfontosabb része a reguláris kifejezések széles körű támogatása és alkalmazása, ezáltal kiválóan alkalmas nagy méretű szöveg- vagy adatfile-ok egyszerű feldolgozására. Egyik elterjedt felhasználása a CGI-szkriptek készítése. Nagyon sokan felhozzák a rovására, hogy kifejezetten könnyű benne olvashatatlan kódot készíteni, de persze ez a programozótól függ: Perlben éppúgy lehet szép, olvasható programot készíteni, mint ahogy olvashatatlant bármely egyéb nyelven.
Hol található meg a Perl?Ha a gép operációs rendszere Unix, Linux, BSD vagy más, ezeken alapuló operációs rendszer, akkor nagyon nagy valószínűséggel van rajta Perl, de ha nincs, akkor is nagyon könnyű letölteni az internetről. Windows-os és Mac számítógépekre ingyenesen letölthető például az ActivePerl disztribúció (lásd külső hivatkozások). A Perl előnyei és hátrányaiElőnyei:
Hátrányai:
A névrőlA nyelvet eredetileg Pearl-nek hívták, ami angolul gyöngyöt jelent. Larry Wall rövid és pozitív hangvételű nevet keresett a nyelvnek, azonban a szótárban végignézve az összes három- és négybetűs szót, egyik sem tetszett neki igazán. Megfordult a fejében az is, hogy feleségéről, Gloriáról nevezze el az új nyelvet. Végül a Pearl szóra esett a választása Máté evangéliuma 13:46 szerint: „the pearl of great price”. A hivatalos kiadás előtt azonban rájött, hogy sajnos már létezik ilyen névvel programnyelv, így gyorsan megváltoztatta a név írásmódját, kihagyva az "a" betűt. Számos betűrövidítést társítanak a névhez, mint például humorosan a Pathologically Eclectic Rubbish Lister (kb. betegesen válogató szemét-listázó). A leginkább elterjedt és szakkönyvekben, illetve a Perl saját oldalán is használt rövidítés-magyarázat a Practical Extraction and Report Language (praktikus (szöveg)kinyerő és jelentéskészítő nyelv). Ez a magyarázat ráadásul összecseng az eredeti Pearl névvel is, amennyiben az And szót is bevesszük a rövidítés betűi közé. A nevet nagy kezdőbetűvel használjuk (Perl) ha magára a programozási nyelvre hivatkozunk, kicsivel (perl) pedig, ha az fordító-értelmező programra. Ahogy azt a Perl közösség is állítja: „Only perl can parse Perl” (csak a perl képes a Perlt értelmezni). Nem tanácsos azonban a nevet végig nagy betűkkel (PERL), szigorúan betűrövidítésként írni. KiejtésA perl programnyelv kiejtése angolszász nyelvterületen megegyezik az angol pearl szó kiejtésével, azaz /pɜːl/, ami rímel a girl angol szóra. Ennek ellenére magyar anyanyelvű programozók körében gyakori a magyar fonetikus kiejtés is. Perl humorUgyanúgy, mint a C nyelvben, a Perlben is népszerűek az elborult lelkivilágú programírási versenyek. Ezek győztesei olyan kódokat produkálnak, melyekről órákig tart megállapítani, hogy voltaképpen mit is csinálnak, azonban lefuttatva általában valamilyen egyszerű műveletet hajtanak végre – például kiírják, hogy „Helló világ!” (Hello world!). Népszerű foglalatosság Perlben verset írni, tehát olyan programkódot, ami értelmezhető a perl fordító által, de olvasható angol nyelvű versként is. Ez a hobbi többé-kevésbé egyedi a programnyelvek között, nagyrészt annak köszönhetően hogy a Perl legtöbb utasítása angol szó. A legújabb verseket rendszeresen közzéteszik a Perl Poetry oldalon. Érdekes még a Perl golf. Ugyanúgy mint a fizikai golfban, a lényeg itt is a cél elérése minél kevesebb ütéssel, az ütések azonban billentyű leütést jelentenek. Egy feladat lehet például a „leghosszabb anagramma megtalálása a beolvasott szövegben”. A versenyzők egymást túllicitálva írnak minél kevesebb billentyű leütéssel begépelhető programkódokat. Az egyik legbizarrabb szórakozás a Lingua::Romana::Perligata CPAN modul, mely képes arra, hogy latin nyelven íródott szöveget értelmezzen és hajtsa végre azt, módot adva a latin nyelvű Perl programozásra. AlapokA Perl szabad szoftver, amely az Artistic licence és a GPL alatt érhető el. A Perl használatára jó példa, hogy a Wikipédia is egy Perlben írt CGI szkriptként működött 2002 januárjáig. (A lecserélésének oka sem a Perl bármilyen káros tulajdonsága volt – egyszerűen azok a programozók, akik újraírták, nem a Perlt ismerték jobban.) Egy másik nagyobb alkalmazóként a Slashdot.org említhető, amelyet a Perlben írt Slashcode működtet. Webes alkalmazások esetében a Perlt gyakran Apache webszerverrel és annak mod perl moduljával használják. A nyelvet támogatói és becsmérlői is egyaránt tisztelik szintaxisa és sajátosságai miatt. A két tábor közötti különbség azonban abban rejlik, hogy ezt erényként vagy vétekként értékelik-e. Tulajdonságai miatt gyakran hasonlítják a természetes nyelvekhez (mint az angol), illetve az evolúcióhoz. Larry Wall így érvel:
Felismerve „csúnya, de hasznos” természetét, a tevét választották a Perl kabalafigurájává, és mivel az O’Reilly kiadó által megjelentetett Perl programozás (Programming Perl) című könyv borítójára is a teve került, ezt programozói körökben egyszerűen csak teve-könyvnek (camel book) hívják. ImplementációA Perl egyik bástyája a CPAN, melyről hatalmas mennyiségű, ingyenesen használható modul tölthető le, melyek az elméleti matematikától az adatbázis kezelésen keresztül a hálózati implementációkig sok-sok mindent felölelnek. A CPAN moduljainak túlnyomó többsége az Artistic licence, a GPL, vagy esetleg mindkettő alatt használható. 2004-ben a CPAN több mint 4000 szerző által írt moduljainak száma meghaladta a 7000-et. A CPAN.pm is egy perl modul, melynek segítségével további modulokat lehet letölteni és telepíteni a CPAN-ról vagy tüköroldalairól, tetszés szerint interaktívan, vagy akár teljesen automatikusan. A jelenlegi verzióA jelenlegi az 5.10.0-as verzió – melyet 2007. december 18-án adtak ki – már teljes Unicode támogatást nyújt. A következő generációs Perl6 nyelv fejlesztése folyamatban van, ezt már a több programozási nyelvet is támogató, Parrot-nak elnevezett virtuális gép fogja futtatni. A Perl működéseBár a Perl hordozza az interpretált nyelvek minden előnyét, mégsem szigorúan sorról-sorra értelmezi a forráskódot, hanem először egy átmeneti belső formátumra alakítja, amelyet futtatás előtt optimalizál. Ez a működés lehetővé teszi, hogy a szintaktikai hibák már fordításidőben észlelhetők legyenek, a szubrutinok hívásai pedig még a szubrutin definíciója előtt szerepelhetnek a forrásban. Az 5.005-ös verzió óta lehetővé vált az átmeneti bájtkód elmentése későbbi futtatásokhoz, amellyel megspórolható a kezdeti fordítási fázis. Mindenképpen idekívánkozik, hogy a legtöbb Linuxos (Unixos) gépen a Perl értelmező a /usr/bin könyvtárban van, és hogy alapvető elv egy program elkészítésénél a hordozhatóság, ezért be kell írni a forrás legelső sorába:
#!/usr/bin/perl
ez a Perl-nek csak egy megjegyzés, viszont segít egyes programokat (főként parancsértelmezőket, mint pl. bash) abban, hogy rájöjjenek, hogy mivel is lehetne futtatni a programot. AdatszerkezetekHárom alapvető adatszerkezet van: skalár, lista (másik nevén tömb) és asszociatív tömb (hash).
$skalar = "Ez egy szoveg"; # skalár változó $szamskalar = 123.456; # skalár szám értékkel
@1tomb = (1011,1012,1013,1014,1015,1016,); # egy tömb @2tomb = (2000,2100,2200,2300,2040,2045,); # egy tömb @8tomb = (8000,8100,8400,8245,); # egy tömb $i = $1tomb[0]; # a tömb legelső eleme
%asszoc = ('nev1','adat1','nev2','adat2'); # egy asszoc tömb, figyeljük meg hogy páros számú elem van felsorolva %asszoc = ( # az előző deklaráció más (könnyebben áttekinthető) 'nev1' => 'adat1', # stílusban írva 'nev2' => 'adat2' ); $asszoc{'nev3'} = 'adat3'; # új elem hozzáadása az asszociatív tömbhöz delete $asszoc{'nev2'}; # elem törlése az asszociatív tömbből Kezdetben zavaró lehet, hogy egy tömb, asszociatív tömb elemének lekérdezésekor is $-jelet kell tenni a változó neve elé, azonban mindig gondoljunk arra, hogy a $, % és @ jelek használata attól függ, hogy mit is szeretnénk értékként visszakapni. Vezérlő szerkezetekA Perl vezérlő szerkezetei a C és Java nyelvekéire hasonlítanak. Ciklusok''címke'' while ( ''kifejezés'' ) ''blokk'' ''címke'' while ( ''kifejezés'' ) ''blokk'' continue ''blokk'' ''címke'' for ( ''kifejezés1'' ; ''utasítás2'' ; ''utasítás3'' ) ''blokk'' ''címke'' foreach ''változó'' ( ''lista'' ) ''blokk'' ''címke'' foreach ''változó'' ( ''lista'' ) ''blokk'' continue ''blokk'' ahol a blokk egy vagy több Perl utasítás kapcsos zárójelek között: { ''utasítás(ok)'' } A kettősponttal lezárt címkét a ciklusvezérlő utasításokban használhatjuk.
Beágyazott ciklusokban címkével együtt használva az utasításokat, azok a címkének megfelelő cikluson értelmeződnek, lehetőséget adva pl. egy belső ciklusban egy külső megszakítására. A for szerkezet szemantikája megegyezik a C nyelvvel. A kifejezés1 még az első kör előtt kiértékelődik; a kifejezés2 minden iteráció előtt értékelődik ki és amennyiben hamisnak bizonyul, úgy a ciklus befejeződik; a kifejezés3 pedig minden egyes iteráció végén hajtódik végre. A foreach szerkezetben a var egy skaláris változót jelöl, aminek elhagyása esetén a beépített ciklusváltozó, a $_ veszi fel az értékeket. Ráadásképpen bármely egyszerű kifejezés (ami nem képez blokkot) végrehajtható a akár következő formákban is: while ( ''kifejezés'' } until ( ''kifejezés'' ) Hasonlóképp készíthető hátultesztelő ciklus, ahol a blokk a kifejezés értékétől függetlenül először biztosan lefut. Ezt a do utasítással kell kezdeni: do ''blokk'' while ( ''kifejezés'' ); do ''blokk'' until ( ''kifejezés'' ); Vigyázat! Ezeket az egyszerűsített kifejezéseket a Perl nem tekinti teljes értékű ciklusnak, így ezekben nem használhatóak a next, last és redo ciklusvezérlő utasítások! Feltételes elágazásokif ( ''kifejezés'' ) ''blokk'' Amennyiben a kifejezés igaz, úgy végrehajtódnak a blokkban szereplő utasítások. unless ( ''kifejezés'' ) ''blokk1'' else ''blokk2'' Amennyiben a kifejezés hamis, úgy végrehajtódnak a blokkban szereplő utasítások. if ( ''kifejezés'' ) ''blokk1'' else ''blokk2'' Ha igaz a kifejezés, akkor a blokk1 fut le, ellenkező esetben pedig a blokk2. if ( ''kifejezés1'' ) ''blokk1'' elsif ( ''kifejezés2'' ) ''blokk2'' else ''blokk3'' Ha a kifejezés1 igaz, akkor a blokk1 értelmeződik, ellenkező esetben megvizsgálja a kifejezés2-t, és ennek megfelelően vagy a blokk2 vagy pedig a blokk3 lesz értelmezve. A Perl a kifejezéseket minden esetben igaz-hamis értékekként kezeli. Ha a kifejezés számnak tekinthető, akkor bármely nem nulla érték igazként értékelődik. Ha a kifejezés szöveges érték, akkor bármely nem nulla hosszúságú szöveg igaz, kivéve a "0"-t. "0" hamis "0.0" igaz "00" igaz "-0" igaz -1 igaz Ha listát vagy asszociatív tömböt írunk a kifejezés helyére, akkor annak elemszáma értékelődik ki, tehát az üres lista és asszociatív tömb hamis lesz. Kifejezésmódosító szerkezetekEgyszerű kifejezésekben, értékadásokban a ''utasítás'' while ( ''logikai kifejezés'' ) ''utasítás'' until ( ''logikai kifejezés'' ) ''utasítás'' if ( ''logikai kifejezés'' ) ''utasítás'' unless ( ''logikai kifejezés'' ) ''utasítás'' foreach ( ''logikai kifejezés'' ) A kifejezésmódosítók nem ágyazhatók egymásba, így a következő kódrészlet szintaktikailag hibás: ''utasítás'' if ( ''logikai kifejezés'' ) for ( ''lista'' ) A Többágú feltételes elágazás (switch)A Perl nyelvben alapesetben nincs külön szerkezet a C nyelvben megszokott SWITCH: { if ( ''logikai kifejezés'' ) { ''utasítás(ok)''; last SWITCH; } if ( ''logikai kifejezés'' ) { ''utasítás(ok)''; last SWITCH; } # ... ''egyéb esetben végrehajtandó utasítások''; } avagy
SWITCH:
''utasítás1'', ''utasítás2'', last SWITCH if ( ''logikai kifejezés'' );
''utasítás1'', ''utasítás2'', last SWITCH if ( ''logikai kifejezés'' );
# ...
''egyéb esetben végrehajtandó utasítások'';
}
vagy if ( ''logikai kifejezés1'' ) { ''utasítás(ok)''; } elsif( ''logikai kifejezés2'' ) { ''utasítás(ok)''; } elsif( ''logikai kifejezés3'' ) { ''utasítás(ok)''; } else { ''egyéb esetben végrehajtandó utasítások''; } Jól példázza azonban a Perl nyelv bővíthetőségét, hogy kiegészítő modul segítségével akár "szabványos" switch szerkezet is használható a Switch CPAN modul használatával use Switch; switch ($val) { case 1 { ''utasítás(ok)'' } case "a" { ''utasítás(ok)'' } case [1..10,42] { ''utasítás(ok)'' } case /\w+/ { ''utasítás(ok)'' } ''...'' else { ''utasítás(ok)'' } } Ezzel azonban bánjunk óvatosan, mivel a Switch modul gyakorlatilag átírja a programkódot az első megoldásra, ezáltal egyes esetekben megnövekedhet a sorok száma. Ekkor egy későbbi hibajelzés olyan sorra mutathat, ahol valójában nem is szerepel a kérdéses hivatkozás. Bonyolultabb adatszerkezetekHivatkozások segítségével az alaptípusoknál sokkal összetettebb adatszerkezetek is létrehozhatók, pl. olyan névsor készíthető, amiben egy névhez több adatot is lehet rendelni (születés helye, ideje, lakcím stb.), míg egyszerű (egy dimenziós) asszociatív tömbök segítségével csak egy adatot lehet minden kulcshoz hozzárendelni. Skaláris %tomb1 = ( nev1 => 'lakcím1', nev2 => 'lakcím2', }; %tomb2 = { nev1 => { lakcim => 'lakcím1', telefonszamok => [ 'telefonszám1', 'telefonszám2' ], szuletes => { helye => 'szül.hely1', ideje => évszám1, }, }, nev2 => { lakcim => 'lakcím2', telefonszamok => [ 'telefonszám3', 'telefonszám4', 'telefonszám5' ], szuletes => { helye => 'szül.hely2', ideje => évszám2, }, }, }; print $tomb1{nev2}; # ''lakcím2'' print $tomb2->{nev1}->{szuletes}->{helye}; # ''szül.hely1'' print $tomb2->{nev2}->{telefonszamok}->[0]; # ''telefonszám3'' Függvények, szubrutinokA Perlben a függvényeket a sub terfogat { my $oldalhossz = shift; return $oldalhossz ** 3; } my $oldal = 16; print terfogat( $oldal ); A paramétereket nevesíthetőek is a függvénynek asszociatív tömböt adva át paraméterként: sub udvozlet { my %szemely = @_; return "Szia $szemely{vezeteknev} $szemely{keresztnev}\n"; } print udvozlet( vezeteknev => 'Szabo', keresztnev => 'Janos', ); Reguláris kifejezésekA Perlben nagyon hatékony módon lehet mintaillesztést végezni szabályos kifejezések (angolul: regular expression) segítségével. A perl szabályos kifejezések eredetileg a Unix Version 8 szintaxisát követték, de azóta a perl más irányba fejlődött tovább, s mára fogalommá vált a perl-kompatibilis szabályos kifejezés. Az m// (match) operátor azt vizsgálja meg, hogy egy string illeszkedik-e egy adott szabályos kifejezéshez. Például az alábbi kifejezés értéke pontosan akkor igaz, ha az $x string tartalmazza az abc részt: $x =~ m/abc/ Az abc string helyén állhat összetettebb szabályos kifejezés is, például a . speciális karakter tetszőleges karaktert jelöl. Az alábbi kifejezés igaz értékű, ha két a betű között egy tetszőleges karakter áll valahol az $x stringben. $x =~ m/a.a/ Ha a kifejezést i (ignore case) kapcsolóval bővítjük, akkor a kis- és a nagybetűk azonosnak számítanak a mintaillesztésnél. A következő kifejezés igaz értékű, ha az $x string tartalmazza a Nemecsek szót, függetlenül attól, hogy az kis- vagy nagybetűkkel van-e írva. $x =~ m/Nemecsek/i Az s// (substitute) operátor adott szabályos kifejezést keres és lecseréli azt a megadott kifejezésre. A következő programsor lecseréli a ló szó első előfordulását tehén-re az $tej stringben. $tej =~ s/ló/tehén/; A g (global) kapcsolóval a csere globálissá tehető. Az alábbi programsor lecseréli a megszorítás szó összes előfordulását reformra a $cikk stringben. $cikk =~ s/megszorítás/reform/g; Egyszerű példaprogramokA legegyszerűbb "Szia világ!" program a következőképp fest Perlben: #!/usr/bin/perl -w print "Szia világ!\n"; Külső hivatkozások
|
This article is from Wikipedia. All text is available under the terms of the GNU Free Documentation License.
Mercedes Car
This site monitored by SitePinger.net