|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Menu
Distributions (131)
bootable [55]
commercial [7] no-commercial [42] unclassified [20] [7]
Software (10844)
|
Perl (8) - Některé základní vestavěné funkceVestavěné funkce usnadňují základní úkony. Udělejme si nyní malý přehled, abychom poznali alespoň některé základní možnosti. Dále v průběhu seriálu budeme postupně poznávat další.
Jako snad v každém rozšířeném programovacím jazyce jsou i součástí Perlu funkce. Funkce je nějaký program uvnitř programu, kterému je obvykle předáván parametr nebo parametry (pravidlem to ale není) a na základě něj vrátí funkce určitou hodnotu, vytiskne něco na výstup nebo provede jinou činnost. Protože mají funkce návratovou hodnotu, jsou to v kontextu volání výrazy. Nejméně dvě funkce jsme již poznali: print a chomp. Parametr funkce se zapisuje do závorek. Jestliže závorky neuvedeme, Perl většinou sám pozná, co argumentem je a co ne. Proto můžeme závorky téměř vždy vynechat. Tuto konvenci ostatně u print používáme stále a stejně tak ji budeme používat u dalších vestavěných funkcí. Později budeme psát naše vlastní funkce. Při volání takových funkcí závorky zpravidla používat budeme. To samé platí o jinak získaných funkcích, které byly do našeho kódu nějak exportované. Matematické funkceZačněme u funkcí, které jsou jako funkce chápány v matematice. Absolutní hodnota potřetíPosledně jsme vylepšovali náš příklad na výpočet absolutní hodnoty tak, aby byl interaktivní. Absolutní hodnota je příklad jako kovaný pro použití funkce. Místo zdlouhavého testování, zda je vstupní číslo záporné nebo není, použijeme předdefinovanou funkci abs:
Funkce abs přijímá jako parametr číslo a vrací jeho absolutní hodnotu. Tu lze získat přiřazením této funkce do proměnné. Pokud chceme návratovou hodnotu funkce přímo vytisknout, uveďme ji jako parametr funkce print. Goniometrické funkce
Víme, že tan-1 (1) = pi / 4. Po vynásobení rovnice číslem 4 tak získáme Ludolfovo číslo. Příklad také ilustruje nepovinnost psát závorky i v případech, kdy má funkce více argumentů.
Další matematické funkce
Funkce pro práci s řetězci
Funkce substr - ořezávání a nahrazování v řetězcíchsubstr je velmi obecná a často používaná funkce. Pracuje s podřetězci - vyhledává je v řetězcích, případně je nahrazuje jinými. Řadu speciálních případů volání lze nahradit voláním jednodušších funkcí, které postupně poznáme. Často také lze s řetězcem manipulovat jako s polem, což bývá často rychlejší. Funkce substr má celkem 4 parametry. Zde je schéma volání:
První parametr určuje řetězec, se kterým bude substr pracovat. Druhým parametrem je pozice, která určuje začátek podřetězce. Další parametr definuje, kolik znaků bude obsahovat podřetězec. Posledním parametrem říkáme, čím chceme vybraný podřetězec nahradit. Povinné jsou jen první dva argumenty.
Hodnoty od a kolik mohou být také záporné. U od to znamená první pozici na konci atd., u kolik určujeme, kolik znaků má zůstat do konce řetězce.
substr má ještě jednu možnost zápisu. Paradoxem je, že se v něm funkce vyskytuje nalevo od operátoru přiřazení. To je napříč programovacími jazyky naprosto unikátní jev. Tyto zápisy mají na řetězec stejný efekt:
Takhle to pak vypadá:
Opět jde ale o ukázku, kterou je dobré vidět a zase na ni zapomenout, neboť bychom si zbytečně znepřehledňovali kód. Hledání podřetězcůObě funkce mají 3 parametry:
Funkce index a rindex vyhledávají podřetězce uvnitř řetězců. Vracejí pozici prvního znaku hledaného podřetězce v řetězci. Poslední parametr je nepovinný a specifikuje pozici, od které začíná hledání. Není-li v řetězci podřetězec nalezen, vrací funkce -1. index hledá první výskyt, rindex poslední výskyt.
Funkce dieUvedení funkce die znamená výjimku a konec programu. Ty příkazy, které jsou za die, se neprovádí. Jako parametr je možné uvést hlášku, která se zobrazí na výstupu.
Pokud parametr neukončíme koncem řádku, automaticky se vypíše i místo, kde byla funkce die volána. Zatím se této funkci nebudeme věnovat podrobněji. Brzy na ni dozajista opět narazíme. Funkce exitdie a exit mají podobný význam. die, jak už víme, ukončí okamžitě program. exit také. Rozdíl je v tom, kdy se tyto funkce volají. Nám bude zatím stačit, že exit nevydá žádné hlášení o chybě (nemá žádný výstup). Definovanost proměnnýchFunkce defined rozlišuje nedefinovanou hodnotu od všech ostatních - včetně 0 nebo prázdného řetězce. V případě nedefinované hodnoty vrací false. (Pseudo)náhodaNaučme se generovat náhodné číslo z rovnoměrného rozdělení. Nejprve musíme inicializovat generátor náhodných čísel. K tomu máme příkaz srand bez parametrů.
srand;
V tuto chvíli spustil Perl stopky. Zbývá z nich zachytit nějakou hodnotu.
$i = rand 983;
Do proměnné $i bylo přiřazeno náhodné desetinné číslo z intervalu [0; 983]. Neuvedeme-li mez, vrací funkce hodnoty z intervalu [0; 1]. Chceme-li realizace z diskrétního rovnoměrného rozdělení, dosáhneme toho zaokrouhlením jednotlivých realizací. Například pro generování z dvouprvkové množiny {0, 1} (nebo-li true/false) bychom psali toto.
$i = int rand 2;
Příklad - řešení rovnice 2. stupněProgramovat se nelze naučit čtením manuálů nebo opisováním kódu z učebnic, ale psaním svých programů. Je vhodné, aby si každý, kdo se chce naučit programovat, zkusil sám něco napsat. Zde je příležitost. Zadání úlohy zní: Napište program, který na základě zadání koeficientů ze standartního vstupu spočítá kořeny kvadratické rovnice v množině reálných čísel a vypíše je na výstup (nezapomeňte na všechny podmínky). ŘešeníTakto rozsáhlý příklad jsme zatím nedělali. Sám algoritmus není obtížný, ale je třeba si průběžně uvědomovat, co je v kterém kroku potřeba udělat a co vše může nastat. U všech větších příkladů se v seriálu budeme snažit postupovat tak, jak bychom ho pravděpodobně řešili na základě intuice. V návodech pro začátečníky by zdrojový kód neměl být vysvětlován řádek po řádku, aniž by byly přiblíženy myšlenky, kterými se k výslednému kódu dospělo. Tento příklad je ale jedním z těch jednodušších, které lze řešit i metodou od prvního řádku k poslednímu. Takže nejdříve načteme data ze vstupu:
Poté už můžeme začít s výpočtem. Vzorec x1 = (-b + odmocnina(b^2 - 4*a*c)) / (2*a) popř. x2 = (-b - odmocnina(b^2 - 4*a*c)) / (2*a) jistě každý zná. Je nutné si uvědomit podmínky řešitelnosti - tj. dávat si pozor jestli neodmocňujeme záporné číslo, nedělíme nulou nebo se nemění počet řešení. Nejprve ošetříme podmínkami speciální případy a poté dopíšeme obecné řešení. Ošetřme tedy případ, kdy je diskriminant záporný (pro větší názornost používám zápis $b ** 2 - 4 * $a * $c < 0, ale samozřejmě lze nerovnici upravit a použít $b ** 2 < 4 * $a * $c):
Pokud je diskriminant roven nule, řešení je jen jedno:
Další speciální situace nastane, je-li koeficient a = 0. V tom případě jde o lineární rovnici. Do podmínky zahrňme i test koeficientu b, protože to je další speciální případ.
Je-li totiž i koeficient b = 0, jedná se o rovnici nultého stupně. Ta má jako řešení buď všechna reálná čísla a nebo řešení nemá.
Všechny speciální případy jsou vyřešeny, tak se můžeme pustit do obecného řešení. Sem se program dostane pouze pokud nevyhověly vstupní hodnoty některému předchozímu případu.
Poznámka: Samozřejmě to není jediné řešení problému. Další možností by mohla být například podmínka if ($a == 0){ ... } else { ... }, v jejíž větvích by byly další podmínky.. Zde máme výsledek:
V posledním případě byly řetězce automaticky konvertovány na čísla.
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 (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 (49) - Tabulky symbolů a typegloby 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 |