![]() ![]() |
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
![]() ![]() ![]() ![]() ![]() ![]() |
|
Soustava | Zápis | Použitelné znaky |
---|---|---|
desítková | klasicky | 0-9 |
osmičková | před číslem je 0 | 0-7 |
šestnáctková | před číslem je 0x | 0-9, a-f, A-F |
dvojková | Před číslem je 0b | 0, 1 |
Jestliže použijeme jiné znaky než ty z uvedených intervalů, obdržíme většinou chybovou hlášku.
V zápisu lze používat takzvané unární operátory + a -. Je to znaménko + nebo - před číslem. Příkladem může být -18 nebo +95. Přívlastek unární se udává proto, že má takový operátor pouze jediný operand. Operandem je myšlena hodnota vcházející do operace. Mimo unární operátory existují v Perlu ještě binární a ternární.
Delší čísla mohou obsahovat pro přehlednost podtržítka. Při vyhodnocení jsou odstraněny.
Jako příklad si uveďme, jakými různými způsoby se dá napsat číslo 2345:
Proměnné můžeme sčítat, odčítat, násobit, dělit nebo s nimi jinak operovat. Zde je tabulka standardních matematických operátorů:
Operátor | Operace | Příklad | Výsledek |
---|---|---|---|
+ | sčítání | 9 + 15 | 21 |
- | odčítání | 6 - 4 | 2 |
* | násobení | 3 * 5 | 15 |
/ | dělení | 9 / 4 | 2.25 |
** | umocňování | 3 ** 4 | 81 |
% | zbytek po celočíselném dělení | 9 % 4 | 1 |
U umocňování je levý operand základem a pravý mocnitelem (exponentem). Takže zápis 3 ** 4 v Perlu je ekvivalentní matematickému zápisu 34. Pozor na to, že 3 ^ 4 znamená něco úplně jiného.
Zbytek po celočíselném dělení (modulus) se dá vysvětlit takto: levý operand vydělíme pravým a výsledné číslo zaokrouhlíme celočíselně dolů (to je výsledek celočíselného dělení). Zaokrohlené číslo vynásobíme pravým operandem a tento nový výsledek odečteme od levého operandu. Získaná hodnota je modulus.
Zde je několik triviálních příkladů:
$a = 1;
$b = 2;
$c = 4;
$soucet = $a + $b; # výsledkem je 1 + 2 = 3
$rozdil = $c / $a; # 4 / 1 = 4
$v1 = $b + $b ** $c; # 2 + 2 ^ 4 = 18
$v2 = ($b + $b) ** $c;# (2 + 2) ^ 4 = 256
$v3 = 5 + 9 * 10; # 95
$v4 = (5 + 9) * 10; # 140
Stejně jako v matematice lze závorkovat tam, kde potřebujeme změnit prioritu operací.
Přiřazování je základní operací a věnovali jsme mu již část minulého dílu. Vysvětlili jsme si, jak funguje operátor =. Ten přiřadí do proměnné určenou hodnotu. Dnes se podíváme na jiné přiřazovací operátory.
Tabulka přiřazovacích operátorů pro čísla s přepisem na standardní operátor =:
Operátor | Příklad | Přepis | Nová hodnota $p pro původní hodnotu $p = 10 |
---|---|---|---|
= | $p = 3 | $p = 3 | 3 |
+= | $p += 3 | $p = $p + 3 | 13 |
-= | $p -= 3 | $p = $p - 3 | 7 |
*= | $p *= 3 | $p = $p * 3 | 30 |
/= | $p /= 3 | $p = $p / 3 | 3.33333333333333 |
**= | $p **= 3 | $p = $p ** 3 | 1000 |
%= | $p %= 3 | $p = $p % 3 | 1 |
++ | $p++ | $p = $p + 1 | 11 |
-- | $p-- | $p = $p - 1 | 9 |
Pro názornost se podívejme, jak bychom mohli tyto operátory zapsat v programu. V proměnné $p je hodnota 10. Zdvojnásobme ji, přičtěme 12, umocněme dvěma a vydělme 4. Vzniklou hodnotu dělme 15 a zbytek po celočíselněm dělení tiskněme na výstup. Napíšeme si trochu neohrabaný program, který to spočítá.
#!/usr/bin/perl
$p = 10; # V proměnné $p je hodnota 10
$p *= 2; # Zdvojnásobme ji,
$p += 12;# přičtěme 12,
$p **= 2;# umocněme na 2.,
$p /= 4; # a vydělme 4.
$p %= 15;# Vzniklou hodnotu dělme 15 a zbytek po celočíselném dělení
print "Řešením úlohy je číslo $p.\n";# tiskněme na výstup
inkrementace je zvýšení hodnoty v proměnné o 1. Dekrementace je naopak snížení hodnoty v proměnné o 1. Jak funguje inkrementace?
$p = 10;
$p++; # Hodnota $p se zvýší o 1
print $p# Vytiskne hodnotu 11 - tedy hodnotu o 1 větší než byla původní hodnota $p
Dekrementace je totéž obráceně (1 se odečítá) a zapisuje se operátorem --.
$p = 10;
$p--;
print $p # tiskne 10 - 1 = 9
Tyto zápisy jsou tedy ekvivalentní:
$p = $p + 1;
$p += 1;
$p++;
Výhodou operátoru inkrementace je zejména přehlednost.
Existuje několik druhů zápisu operátorů podle toho, v jakém pořadí se uvádějí operátory a operandy. I na pořadí zápisu samozřejmě výsledek závisí.
Způsoby notace si ukážeme na operátorech ++ a --. Ty lze totiž napsat i před proměnnou. To má význam jen v případě, kdy nepoužijeme zápis osamoceně, ale například při přiřazení. Nejen, že inkrementace ovlivní hodnotu proměnné, ale celá operace (stejně jako každá jiná operace) má takzvanou návratovou hodnotu, kterou můžeme také někam přiřadit. Použijeme-li zápis před proměnnou (prefixový zápis), bude hodnota nejdříve inkrementována, až poté přiřazena (tj. až poté se vyhodnotí návratová hodnota). Při zápisu za proměnnou (postfixový zápis), bude nejprve přiřazena a až poté inkrementována.
Podívejme se na příklad pro postfixový zápis:
$a = 3;
$b = $a++;#do $b se přiřadí hodnota proměnné $a a až potom se zvýší $a o 1. $b tedy bude mít hodnotu 3
print $a; #4
print $b; #3
u Prefixového zápisu je výsledek jiný:
$a = 3;
$b = ++$a;#tady je to naopak. Nejdříve se $a zvýší o 1 a až potom se hodnota $a přiřadí do $b
print $a; #4
print $b; #4
Takto je to u inkrementace a dekrementace, ale každý operátor funguje svým způsobem. Nemá smysl se tím nyní příliš zabývat, protože zápis bývá většinou intuitivní.
Infixová notace znamená, že je operátor mezi operandy. Například 5 + 9. U unárních operátorů nemá význam.
Proměnné mohou uchovávat také řetězce.
Dostupnými operacemi s textem v Perlu, které si dnes představíme, je zřetězení a opakování. Zřetězení používá operátor tečky a jeho výsledkem je spojení řetězců z operandů na levé a pravé straně.
$a = "larry" . "wall";
print $a; # vytiskne larrywall
$jmeno = "larry";
$prijmeni = "wall";
$cele_jmeno = $jmeno . " " . $prijmeni;
print $cele_jmeno; # vytiskne larry wall
Operátor opakování se se bude hodit studentům. Chceme-li 100x vypsat nějaký řetězec, použijeme zápis:
print "Budu nosit domácí úkoly.\n" x 100;
Jde vlastně o autozřetězení, kdy několikkrát postupně zřetězujeme s původním řetězcem. Zkusme spustit program:
$./program.pl
Budu nosit domácí úkoly.
Budu nosit domácí úkoly.
Budu nosit domácí úkoly.
Budu nosit domácí úkoly.
Budu nosit domácí úkoly.
..... (ještě 94×)
Budu nosit domácí úkoly.
$
Stejně jako u řetězců můžeme využít několik přiřazovacích operátorů.
Operátor | Příklad | Přepis | Nová hodnota $p pro původní hodnotu $p = "abc" |
---|---|---|---|
= | $p = "xxx" | $p = "xxx" | "xxx" |
.= | $p .= "def" | $p = $p . "def" | "abcdef" |
x= | $p x= 3 | $p = $p x 3 | "abcabcabc" |
Co se stane, když provádíme numerické výpočty s řetězci a naopak - řetězcové operace s čísly? Již jsme naznačili, že Perl automaticky převede řetězec na číslo nebo číslo na řetězec.
Pravidla konverze jsou prostá. Jestliže na začátku řetězce není číslo, převede Perl řetězec na 0. V opačném případě je řetězec převeden na nejdelší číslo, kterým řetězec začíná a ostatní znaky jsou vypuštěny. Přitom se nebere ohled na bílé znaky na začátku.
print 10 + "265pps";
# vytiskne 275
print 10 + "pps";
# vytiskne 10
print "2k5" + "123px";
# vytiskne 125
print "2e5" + "123px";
# tady je zrada! Vytiskne 200123, protože "2e5" je konvertováno na 2e5 = 2 * 105, nikoliv na 2
print " 2k5" + "123px";
# bílý znak na začátku (mezera) jako by nebyl, Perl ho ignoruje a řetězec konvertuje na 2.
#Výsledkem tedy je 125
Konverze z čísla na řetězec je intuitivní. Získaný řetězec bude prostě obsahovat číslo.
print 12 . 6;
#vytiskne 126
print "retezec" . 6;
#vytiskne retezec6
V matematice bývá zvykem, že některé operace se vykonávají přednostně. Například umocňování má přednost před násobením a násobení před sčítáním. Pokud výraz obsahuje operátory stejné priority, zpracováváme ho zleva doprava.
Pravidla pro pořadí vykonávání jsou nezbytná, neboť výsledek nemusí být při různém vyhodnocení jednoznačný. K tomu, která operace se kdy vykoná, slouží v Perlu tabulka priorit. Ty operace, které již známe nebo poznáme brzy (horizont dvou dílů), jsou zvýrazněny zeleně:
Operátor | Operace | Asociativita | Arita |
print, sort atd. (nejvyšší priorita) | Operátory pro seznamy (levé) | zleva | |
-> | Dereference | zleva | 2 |
++, -- | Inkrementace, dekrementace | není | 1 |
** | Umocňování | zprava | 2 |
+, -, !, \ | Unární plus, minus, not (logické), odkaz | zprava | 1 |
=~, !~ | Operace pro práci s regulárními výrazy | zleva | 2 |
*, /, %, x | Násobení, dělení, modulus, opakování | zleva | 2 |
+, -, . | Plus, minus, spojení řetězců | zleva | 2 |
>> << | Bitový posun | zleva | 2 |
rand atd. | Pojmenované unární operátory | není | 1 |
<, <=, >=, >, lt, le, ge, gt | Porovnávání | není | 2 |
==, !=, <=>, eq, ne, cmp | Porovnávání | není | 2 |
& | and (bitové) | zleva | 2 |
|, ^ | or, xor (bitové) | zleva | 2 |
&& | and (logické) | zleva | 2 |
|| | or (logické) | zleva | 2 |
.., ... | Operátor rozsahu | není | 2 |
?: | Operátor podmínky | zprava | 3 |
=, +=, -=, *=, /=, .=, x=, **=, %= | Přiřazovací operátory | zprava | 2 |
=>, , | Čárka | zleva | 2 |
open atd. | Operátory pro seznamy (pravé) | není | |
not | not (logické) | zprava | 1 |
and | and (logické) | zleva | 2 |
or, xor (nejnižší priorita) | or (logické) | zleva | 2 |
Čím výše je operátor, tím má vyšší prioritu - a tedy vykoná se přednostně oproti operacím s operátorem pod ním.
Směr vykonávání (asociativita) určuje, jak se bude vykonávat operace se stejnou prioritu. Jsou 3 možnosti:
Přirozenost požadavku asociativity si lze uvědomit na výrazu 8 / 4. Výsledkem je 2, nikoliv 0.5 (8 dělíme čtyřmi, ne opačně, protože výraz se vykonává zleva).
Vlastnosti operátorů jsou tedy obecně priorita, asociativita, počet operandů (arita), případně i typ a kontext operandů.
Chceme-li změnit prioritu, použijeme kulaté závorky. Lze je používat i tam, kde nejsou nutné (třeba když si nejsme prioritou jistí a nechce se nám hledat, ale je to vhodné i tam, kde by si někdo, kdo bude kód v budoucnu číst, taky nemusel být jistý).
Příspívat do diskuze mohou pouze registrovaní uživatelé. |
17.4.2018 0:46 /František Kučera
Dubnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 4. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tématem tohoto srazu bude OpenStreetMap (OSM) aneb svobodné mapy.
Přidat komentář
16.3.2018 22:01 /František Kučera
Kulatý OpenAlt sraz v Praze oslavíme klasicky: u limonády a piva! Přijďte si posedět, dát si dobré jídlo a vybrat z mnoha piv do restaurace Kulový blesk, který najdete v centru Prahy nedaleko metra I. P. Pavlova na adrese Sokolská 13, Praha 2. Sraz se koná ve čtvrtek 22. března a začínáme v 18:00. Heslo: OpenAlt. Vezměte s sebou svoje hračky! Uvítáme, když si s sebou na sraz vezmete svoje oblíbené hračky. Jestli máte nějaký drobný projekt postavený na Arduinu, nějakou zajímavou elektronickou součástku, či třeba i pěkný úlovek z crowdfundingové akce, neváhejte. Oslníte ostatní a o zábavu bude postaráno.
Přidat komentář
13.2.2018 0:41 /František Kučera
Únorový pražský sraz OpenAltu se koná 15. 2. 2018 a tentokrát se vydáme na návštěvu do jednoho pražského datacentra. Sejdeme se v 17:50 v severovýchodní části nástupiště tramvajové zastávky Koh-I-Noor. Po exkurzi se přesuneme do restaurace U Pštrosa (Moskevská 49), kde probereme tradiční témata (svobodný software a hardware, DIY, CNC, SDR, 3D tisk…) a tentokrát bude k vidění i IoT brána od The Things Network.
Přidat komentář
11.2.2018 23:11 /Petr Ježek
Hledáte lehký a rychlý prolížeč PDF souborů? Pokud vás již omrzelo čekat na načítání stránek či jiné nešvary, zkuste xreader.
Přidat komentář
11.2.2018 20:35 /Redakce Linuxsoft.cz
Třetí ročník odborné IT konference na téma Cloud computing v praxi proběhne ve čtvrtek 1. března 2018 v konferenčním centru Vavruška, v paláci Charitas, Karlovo náměstí 5, Praha 2 (u metra Karlovo náměstí) od 9:00 hod. dopoledne do cca 16 hod. odpoledne. Konference o trendech v oblasti cloud computingu nabídne i informace o konkrétních možnostech využívání cloudů a řešení vybraných otázek souvisejících s provozem IT infrastruktury.
Přidat komentář
15.1.2018 0:51 /František Kučera
První letošní pražský sraz se koná již tento čtvrtek 18. ledna od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Vítáni jsou všichni příznivci svobodného softwaru a hardwaru, ESP32, DIY, CNC, SDR nebo dobrého piva. Prvních deset účastníků srazu obdrží samolepku There Is No Cloud… just other people's computers. od Free Software Foundation.
Přidat komentář
14.11.2017 16:56 /František Kučera
Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Zajímá tě DIY, CNC, SDR nebo morseovka? Přijď na sraz spolku OpenAlt – tradičně první čtvrtek před třetím pátkem v měsíci: 16. listopadu od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5).
Přidat komentář
12.11.2017 11:06 /Redakce Linuxsoft.cz
PR: 4. ročník odborné IT konference na téma Datová centra pro business proběhne již ve čtvrtek 23. listopadu 2017 v konferenčním centru Vavruška, v paláci Charitas, Karlovo náměstí 5, Praha 2 (u metra Karlovo náměstí) od 9:00. Konference o návrhu, budování, správě a efektivním využívání datových center nabídne odpovědi na aktuální a často řešené otázky, např Jaké jsou aktuální trendy v oblasti datových center a jak je využít pro vlastní prospěch? Jak zajistit pro firmu či jinou organizaci odpovídající služby datových center? Podle jakých kritérií vybrat dodavatele služeb? Jak volit součásti infrastruktury při budování či rozšiřování vlastního datového centra? Jak efektivně spravovat datové centrum? Jak eliminovat možná rizika? apod.
Přidat komentář
20.2.2018 18:48 /
Ivan Majer
portal
20.2.2018 15:57 /
Jan Havel
Jak využíváte služby cloudu v podnikání?
16.1.2018 1:08 /
Ivan Pittner
verejna ip od o2 ubuntu
15.1.2018 17:26 /
Mira Harvalik
Re: Jak udělat HTML/Javascript swiping gallery do mobilu?
30.12.2017 20:16 /
Michal Knoll
odmocnina