|
|||||||||||||||||||||||||||||||||||||||||||||||||
Menu
Distributions (131)
bootable [55]
commercial [7] no-commercial [42] unclassified [20] [7]
Software (10844)
|
Perl (49) - Tabulky symbolů a typegloby
Kde jsou uložena jména proměnných? Co to jsou typegloby a k čemu jsou dobré?
Tabulka symbolůO tabulce symbolů již jsme se letmo zmiňovali. V ní jsou uloženy jména proměnných, ovladače, formáty, podprogramy a odkazy na ně. Takovou tabulku symbolů má každý balík. Mimo tabulek symbolů existují ještě lexikální prostory, které mají trochu odlišnou funkci. Tam patří lexikálně vymezené proměnné. Lexikálně (tedy pomocí my) lze deklarovat pouze proměnné; nikoliv už ovladače, formáty nebo podprogramy. Lexikální prostor se vztahuje k aktuálnímu bloku. (Z tohoto důvodu lze v jednom bloku deklarovat 2 proměnné zdánlivě stejného jména - jedna z nich patří do tabulky symbolů, druhá do lexikálního prostoru aktuálního bloku.) Podívejme se však na strukturu tabulky symbolů. V Perlu lze pro různé datové typy použít stejné identifikátory ($a, @a, &a atd.). Všechny identifikátory jsou uloženy ve speciálním hashi. Protože nemohou být klíče v hashi duplicitní, nemohou tam vedle sebe existovat dva stejné identifikátory, lišící se jen datovým typem. Z tohoto důvodu jsou v hashi jako hodnoty prvků takzvané typegloby. Typeglob seskupuje stejné identifikátory různých datových typů a díky němu tak může být v tabulce symbolů pro proměnné @p, %p apod. vytvořen jediný prvek. Tabulka symbolů je tedy uložena v hashi. Ten je v každém balíku dostupný pod jménem %jméno_balíku::. Konkrétně - pro balík main existuje tabulka symbolů v hashi %main::. Protože je balík main implicitní, lze použít i zkrácený zápis %::. Vypišme si jako ukázku tabulku symbolů balíku main.
Zkusme nyní ještě voláním tohoto kódu přidat nějaký nový symbol tím, že v programu použijeme novou proměnnou. Připíšeme například tento řádek.
$zzz;
V hashi se nám objevil nový prvek. Na výstupu vidíme následující řádek navíc.
zzz=*main::zzz
Takový tvar mají všechny vytisknuté řádky. Mění se jen jméno typeglobu, tedy v našem případě oba řetězce zzz. Takto můžeme přidávat další jména. Nejen skaláry, ale i pole, hashe atd. Pro každý nový identifikátor se přidá nový řádek. To platí do doby, než přidáme identifikátor stejného jména, které v tabulce již je, neboť, jak bylo uvedeno, typeglob reprezentuje všechny datové typy dohromady. Vlastnosti typeglobůZápis typeglobu vždy začíná znakem *. Již víme, že typeglob zastupuje jakýkoliv datový typ. Zde je pro shrnutí jejich seznam.
Jak se za chvíli přesvědčíme, dá se s typegloby pracovat podobně jako s jinými identifikátory a můžeme je často zaměňovat. Důležitou skutečností je, že typegloby nelze deklarovat pomocí my. Pomocí my se deklarují pouze skaláry, pole a hashe. Lexikální prostory nic jiného obsahovat nemohou. Neméně důležité je i to, že do typeglobů lze přiřazovat odkazy. Z toho budeme dále často vycházet. Typegloby je možné předávat jako parametr podprogramům. Uvnitř podprogramu nelze z výše zmíněného důvodu použít k lokalizaci funkci my. Je nutné typeglobu vytvořit dočasný alias pomocí local. Příklad tohoto jevu je uveden níže. PřiřazeníPřířazení typeglobu umožňuje hromadné kopírování odkazů datových typů stejného identifikátoru. Po přiřazení typeglobu do typeglobu mohou být data zpřístupněna i novou sadou identikátorů. Zde je krátká ukázka.
Proměnné @zaloha i @zzz nyní ukazují na stejnou hodnotu. To znamená, že když změníme jednu z těchto proměnných, obě budou ukazovat na změněnou hodnotu. Další možností přiřazení pouze určitého datového typu. Chceme-li přiřadit odkaz na skalár a zároveň také aby se nepřiřadil odkaz na pole, napíšeme toto.
Použití typeglobůNyní se podíváme na několik příkladů, kde se dají typegloby použít. Pojmenování anonymnymních datPodívejme se na tento bezejmenný podprogram.
Pokud z nějakého důvodu nechceme volat podprogram příkazem
&$sub();
lze ho přes typegloby pojmenovat. Stačí přiřadit proměnnou $sub do nějakého typeglobu.
*podprogram = $sub;
Odteď lze použít i toto volání.
&podprogram();
Naprosto stejně to funguje i pro jiné datové typy. Uveďme si jen ukázku s poli.
Šablony funkcíPomocí typeglobů ve spolupráci se symbolickými odkazy lze v cyklu deklarovat libovolné množství podprogramů s různými jmény, která máme uloženy v poli. Protože jsou k tomu ale potřeba symbolické odkazy, musíme vypnout režim strict "refs".
Nyní máme vytvořené podprogramy f, g, h.
Vytvoření aliasu pro identifikátorPředstavme si, že potřebujeme vytvořit 2 stejné podprogramy různého jména. Máme několik možností. Jednou z nich je prosté přiřazení typeglobu.
Tvoření odkazů podle speciální syntaxePomocí syntaxe *identifikátor{DATOVÝ_TYP} lze získávat odkazy na příslušný datový typ.
Datový typ může být jedním z těchto řetězců.
Tímto způsobem můžeme předávat odkazy na ovladače podprogramům, což by si jinak člověk jen těžko představil.
Ještě jednou předávání ovladačů podprogramůmPokud se vám právě uvedená metoda nezamlouvá, můžete místo ovladače předát rovnou typeglob, což je asi logičtější metoda. Jen je třeba pamatovat, že typegloby nelze vymezovat lexikálně.
Odkazy na ovladačeOvladače jsou specifický datový typ. Nelze je mezi sebou přiřazovat a ani lokalizovat pomocí my nebo local. Tato omezení lze obejít pomocí typeglobů.Pokud máme ovladač ZDROJ a chceme ho přiřadit do ovladače Z, opět to uděláme přes typegloby (možná si ještě vzpomenete, že kdysi jsme si kopírování ovladačů již ukazovali; umí to funkce open). Napíšeme do programu toto.
Podobně, chceme-li ovladač lokalizovat. Použijeme typeglob.
local *ZDROJ;
Ovladače mohou být i řetězci. Možné je toto.
Přesměrování výstupuVypisuje-li nějaký program data na obrazovku a my je chceme přesměrovat do souboru, přiřadíme do *STDOUT jiný typeglob.
Related article
Perl (1) - Dávka teorie na úvod Perl (2) - Úvod do syntaxe Perl (3) - Proměnné Perl (4) - Čísla a řetězce Perl (5) - Podmínky Perl (6) - Pravdivostní výrazy Perl (7) - Vstup poprvé Perl (8) - Některé základní vestavěné funkce Perl (9) - Cykly Perl (10) - Další řídící struktury Perl (11) - Pole - úvod Perl (12) - Pole - základní operace Perl (13) - Hashe Perl (14) - Další nástroje pro seznamy Perl (15) - Výchozí proměnná, heredoc, symbolické odkazy Perl (16) - Regulární výrazy - začínáme Perl (17) - Regulární výrazy - kotvy Perl (18) - Regulární výrazy - množiny znaků Perl (19) - Regulární výrazy - opakování a kvantifikátory Perl (20) - Regulární výrazy - magické závorky Perl (21) - Regulární výrazy - nahrazování Perl (22) - Regulární výrazy - přepínače Perl (23) - Regulární výrazy - rozšířené vzory Perl (24) - Regulární výrazy - příklady Perl (25) - Regulární výrazy - závěr Perl (26) - Podprogramy Perl (27) - Prototypy Perl (28) - Rozsahy platnosti proměnných Perl (29) - Úvod k práci se soubory Perl (30) - Práce se soubory Perl (31) - Testování souborů Perl (32) - Jiné typy souborů Perl (33) - Formátování výstupu - printf Perl (34) - Formátování výstupu - formáty Perl (35) - Vestavěný debugger Perl (36) - Grafické debuggery Perl (37) - Začínáme s moduly Perl (38) - Rozhraní modulu Perl (39) - Pragma Perl (40) - Dodatky k modulům Perl (41) - CPAN Perl (42) - Argumenty příkazového řádku Perl (43) - Přepínače Perl (44) - Dlouhé přepínače Perl (45) - Odkazy Perl (46) - Užití odkazů a anonymní data Perl (47) - Složitější datové struktury Perl (48) - Libovolně složité datové struktury Perl (50) - Uzávěry a iterátory Perl (51) - Signály Perl (52) - Externí příkazy Perl (53) - Režim nakažení Perl (54) - Fork Perl (55) - Eval Perl (56) - Volby příkazu perl Perl (57) - Jednořádkové skripty Perl (58) - OOP - úvod Perl (59) - OOP - typické použití Perl (60) - OOP - dědičnost Perl (61) - OOP - přínos a užití dědičnosti Perl (62) - OOP - přetěžování Perl (63) - OOP - závěr Perl (64) - Projekt - čtečka sportovních výsledků Perl (65) - Projekt - získání dat Perl (66) - Projekt - výběr zápasů a podrobnosti Perl (67) - Projekt - dokončujeme modul Perl (68) - Projekt - zobrazení zápasů Perl (69) - Projekt - online přenos Perl (70) - Plain Old Documentation Perl (71) - Navazování proměnných Perl (72) - Navazování složitějších datových typů Perl (73) - DBM Perl (74) - Sockety Perl (75) - Obsluha více klientů Perl (76) - Síťová hra v kostky Perl (77) - Služby internetu Perl (78) - Databáze - úvod Perl (79) - Databáze - manipulace s daty Perl (80) - Databáze - závěrečné poznámky Perl (81) - CGI - příprava webového serveru Perl (82) - CGI - první skripty Perl (83) - CGI - získávání dat od uživatele Perl (84) - CGI - usnadnění tvorby skriptů pomocí modulu CGI Perl (85) - CGI - generování dokumentu modulem CGI Perl (86) - CGI - cookies Perl (87) - CGI - příklad aplikace Perl (88) - CGI - závěr Perl (89) - Mason - snadné psaní webů Perl (90) - Mason - speciální bloky Perl (91) - Mason - handlery Perl (92) - Mason - závěr Perl (93) - Catalyst - MVC framework pro Perl Perl (94) - Catalyst - základy pro psaní aplikace Perl (95) - Catalyst - šablony Perl (96) - Catalyst - spolupráce s databází Perl (97) - Curses - tvorba textových uživatelských rozhraní Perl (98) - Curses - pozicování a okna Perl (99) - Curses - měření rychlosti psaní Perl (100) - Curses - použití hotových widgetů Perl (101) - Curses - jednoduchý textový editor Perl (102) - Rozšiřování Perlu pomocí XS Perl (103) - Rozšiřování Perlu pomocí SWIG Perl (104) - Testování rychlosti Perl (105) - Testování programových jednotek Perl (106) - Debugování pomocí komentářů Perl (107) - Moose - moderní objektový systém Perl (108) - Moose - základní vlastnosti Perl (109) - Moose - role Perl (110) - Moose - meta API Perl (111) - Pokročilá práce se seznamy Perl (112) - Práce s PDF Perl (113) - Práce s archivy Perl (114) - Tk - úvod Perl (115) - Tk - umísťování widgetů Perl (116) - Tk - základní widgety Perl (117) - Tk - některé pokročilejší widgety Perl (118) - Tk - čas a události Perl (119) - Tk - CD man Perl (120) - Wx - základní práce s widgety Perl (121) - Wx - události Perl (122) - Gtk2 - úvod Perl (123) - Gtk2 - základní práce s obrázky Perl (124) - Gtk2 - události a čas Perl (125) - Gtk2 - vlastní widgety Perl (126) - Gtk2 - textové okno a práce s pozicemi Perl (127) - Gtk2 - hierarchické seznamy Perl (128) - Gtk2 - dialogy Perl (129) - Gtk2 - skládání widgetů Perl (130) - Gtk2 - menu a toolbary Perl (131) - Gtk2 - transparentní okna, tray ikona, výběr souborů Perl (132) - Gtk2 - drag&drop, druid Perl (133) - Gtk2 - úpravy vzhledu aplikací pomocí rc Perl (134) - Gtk2 - Glade Interface Designer Perl (135) - XML - čtení a zápis Perl (136) - XML - DOM a SAX přístupy Perl (137) - Vlákna Perl (138) - Memoizace - cachování podprogramů Perl (139) - Profilling - efektivní odhalování pomalých míst v programu Perl (140) - Profilling - píšeme si vlastní profiler / debugger Perl (141) - Formátování kódu, deparsování, perltidy Perl (142) - Způsoby konfigurování Perl (143) - Struktura datových typů, správa paměti Perl (144) - POE - událostmi řízené programování Perl (145) - POE - aplikace typu klient-server Perl (146) - Perl 6 - jazyk budoucnosti Perl (147) - Perl 6 - regulární výrazy, nové operátory Perl (148) - Perl Culture Perl (149) - Závěr Pozvánka na Český Perl Workshop Perl 5.22.0 a vše okolo Perl 5.24.0 a vše okolo Previous Show category (serial) Next
|
Szukanie oprogramowania
|
|||||||||||||||||||||||||||||||||||||||||||||||
©Pavel Kysilka - 2003-2024 | maillinuxsoft.cz | Design: www.megadesign.cz |