![]() ![]() |
ARCHIV |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
![]() ![]() ![]() ![]() ![]() ![]() |
|
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é. |
28.11.2018 23:56 /František Kučera
Prosincový sraz spolku OpenAlt se koná ve středu 5.12.2018 od 16:00 na adrese Zikova 1903/4, Praha 6. Tentokrát navštívíme organizaci CESNET. Na programu jsou dvě přednášky: Distribuované úložiště Ceph (Michal Strnad) a Plně šifrovaný disk na moderním systému (Ondřej Caletka). Následně se přesuneme do některé z nedalekých restaurací, kde budeme pokračovat v diskusi.
Komentářů: 1
12.11.2018 21:28 /Redakce Linuxsoft.cz
22. listopadu 2018 se koná v Praze na Karlově náměstí již pátý ročník konference s tématem Datová centra pro business, která nabídne odpovědi na aktuální a často řešené otázky: Jaké jsou aktuální trendy v oblasti datových center a jak je optimálně využít pro vlastní prospěch? Jak si zajistit odpovídající služby datových center? Podle jakých kritérií vybírat dodavatele služeb? Jak volit vhodné součásti infrastruktury při budování či rozšiřování vlastního datového centra? Jak efektivně datové centrum spravovat? Jak co nejlépe eliminovat možná rizika? apod. Příznivci LinuxSoftu mohou při registraci uplatnit kód LIN350, který jim přinese zvýhodněné vstupné s 50% slevou.
Přidat komentář
6.11.2018 2:04 /František Kučera
Říjnový pražský sraz spolku OpenAlt se koná v listopadu – již tento čtvrtek – 8. 11. 2018 od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Tentokrát bez oficiální přednášky, ale zato s dobrým jídlem a pivem – volná diskuse na téma umění a technologie, IoT, CNC, svobodný software, hardware a další hračky.
Přidat komentář
4.10.2018 21:30 /Ondřej Čečák
LinuxDays 2018 již tento víkend, registrace je otevřená.
Přidat komentář
18.9.2018 23:30 /František Kučera
Zářijový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 20. 9. 2018 od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Tentokrát bez oficiální přednášky, ale zato s dobrým jídlem a pivem – volná diskuse na téma IoT, CNC, svobodný software, hardware a další hračky.
Přidat komentář
9.9.2018 14:15 /Redakce Linuxsoft.cz
20.9.2018 proběhne v pražském Kongresovém centru Vavruška konference Mobilní řešení pro business.
Návštěvníci si vyslechnou mimo jiné přednášky na témata: Nejdůležitější aktuální trendy v oblasti mobilních technologií, správa a zabezpečení mobilních zařízení ve firmách, jak mobilně přistupovat k informačnímu systému firmy, kdy se vyplatí používat odolná mobilní zařízení nebo jak zabezpečit mobilní komunikaci.
Přidat komentář
12.8.2018 16:58 /František Kučera
Srpnový pražský sraz spolku OpenAlt se koná ve čtvrtek – 16. 8. 2018 od 19:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát jsou tématem srazu databáze prezentaci svého projektu si pro nás připravil Standa Dzik. Dále bude prostor, abychom probrali nápady na využití IoT a sítě The Things Network, případně další témata.
Přidat komentář
16.7.2018 1:05 /František Kučera
Červencový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 7. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát bude přednáška na téma: automatizační nástroj Ansible, kterou si připravil Martin Vicián.
Přidat komentář
31.7.2023 14:13 /
Linda Graham
iPhone Services
30.11.2022 9:32 /
Kyle McDermott
Hosting download unavailable
13.12.2018 10:57 /
Jan Mareš
Re: zavináč
2.12.2018 23:56 /
František Kučera
Sraz
5.10.2018 17:12 /
Jakub Kuljovsky
Re: Jaký kurz a software by jste doporučili pro začínajcího kodéra?