Premium

Získejte všechny články mimořádně
jen za 49 Kč/3 měsíce

Programátorům záleží na barvičkách. Pomáhají jim vyznat se v chaosu

K čemu používají programátoři barvy? Při psaní kódu jim barevné odlišení syntaxe pomáhá vyznat se v textu, vyhledávat překlepy nebo rozpoznat komentář od aktivního kódu. Většina programátorů nedá na zvýrazňování syntaxe dopustit, ale kritici tvrdí, že může být i škodlivé spoléhat na to až příliš.
Zvýraznění syntaxe (ilustrační foto)

Zvýraznění syntaxe (ilustrační foto) | foto: Pavel Kasík - Technet.cz

Psaní počítačového kódu je v mnoha ohledech exaktní proces. Pro někoho je to spíše hra, pro dalšího skládání modulů jako lego kostiček a odlaďování metodou pokus omyl. Skoro každý editor počítačového kódu nabízí uživatelům nástroje, které jim mají práci usnadnit. Jedním z nich je zvýraznění syntaxe.

V čem programátoři pracují

Pro tvorbu počítačového kódu teoreticky stačí jakýkoli textový editor (a následně kompilátor, emulátor nebo interpreter pro spuštění kódu). Většina programátorů ovšem používá specializované editory, které jim nabízejí funkce šité na míru jejich potřebám. Často jde o tzv. vývojové prostředí (IDE).

Tato funkce je stará více než třicet let. Navazuje na starší koncept editorů strukturovaného kódu, které dokonce byly tak přísné, že dokonce neumožňovaly udělat v syntaxi chybu. Programátor prostě vybíral z možných příkazů, takže překlepy vlastně (alespoň ve struktuře) neexistovaly.

Barevné zvýraznění syntaxe oproti tomu do kódu nezasahuje (nebo zasahuje jen minimálně, například doplněním uvozovek a závorek). Programátor píše kód na klávesnici volně, bez omezení, ale zvýrazňovač provádí tzv. parsování a hledá v napsaném textu klíčová slova nebo znaky, které mají speciální (syntaktický) význam. Nejlépe je to vidět na příkladu:

Ukázka kódu v jazyce Python se zvýrazněním syntaxe (nahoře) a bez zvýraznění. Všiměte si zejména zelených komentářů, což je text, který slouží pouze pro přehlednost programátorovi a neprojeví se na běhu programu. Řádek s komentářem začíná mřížkou #, Programátor může komentář použít i k rychlému dočasnému zneplatnění části kódu.

Je zvýraznění syntaxe škodlivé, nebo prospěšné?

Oblíbenost zvýraňování mezi programátory (n=347) v průzkumu Technet.cz

Na první pohled je zvýraznění syntaxe veskrze příjemná funkce, proti které se zdánlivě nedá nic namítat. To nám potvrdili i programátoři, které jsme oslovili v rychlém průzkumu mezi čtenáři Technetu. Více než 96 % hlasujících, kteří se živí programováním, používá zvýrazňování syntaxe a považuje jej za užitečné. Tomu odpovídaly i vzkazy respondentů:

  • „Zvýrazňování syntaxe je užitečné, když někde uděláte chybu a zapomenete středník nebo uvozovky. Zvýrazňování se pak zblázní a vy víte, že něco chybí.“
  • „Nemám rád velké barevné rozdíly, ale uvítám oddělení komentářů a dalších ‚nevýkonných’ bloků.“
  • „Bez základního zvýrazňovaní syntaxe si nedokážu představit programování.“
  • „Existuje vůbec někdo, kdo bez zvýraznění syntaxe ještě programuje?“
  • „Divná otázka. Ani by mne nenapadlo, že by někdo bez zvýrazňování dobrovolně programoval!“
  • „Bez zvýrazňování syntaxe by svět zanikl v chaosu.“

Zvýraznění syntaxe v běžném textu může odvádět pozornost od významu vět (ukázka z Ústavy ČR)

Ale najdou se i programátoři, kteří zastávají zcela opačné stanovisko. „Psaní kódu je často plné komplexních struktur a důležitých detailů,“ píše ve svém příspěvku programátor Linus Åkesson. „Abyste se v něm vyznali, musíte mu rozumět. A v takovou chvíli vám nepomůže zvýraznění syntaxe, protože v takovou chvíli vás zajímá obsah a význam (sémantika).“

Zvýraznění syntaxe je pro Åkessona spíše berlička pro začínající programátory než reálně užitečný nástroj. „Je to, jako když učitel hudby nalepí na klávesy piana barevné nálepky. Pak může říkat ‚stiskni žlutou klávesu‘ místo ‚stiskni F‘. Ale až se žák naučí noty, bude se muset také odnaučit přiřazené barvy.“

Zvýraznění syntaxe podle Åkessona pomáhá pouze s jedním úkolem: odhalí chyby v syntaxi. „Ale takové chyby odhalí kompilátor tak jako tak,“ zdůrazňuje. „Místo toho by se programátoři měli zaměřit na to, co kód vlastně dělá.“ A od toho je prý současné zvýraznění syntaxe odvádí.

Není všechno černobílé

Je jasné, že Åkessonův názor je v naprosté menšině. I největší odpůrci zvýrazňování syntaxe ostatně uznávají, že někdy je tato služba nenahraditelná. Třeba ve chvíli, kdy pomocí funkce plnotextového vyhledávání procházíte svůj kód a najednou se dostanete doprostřed delšího bloku komentáře. V takovou chvíli je zelená (či jiná) barva to jediné, co vám sděluje, že nejde o aktivní kód.

Podle jiných kritiků nejde o to, že je zvýrazňování syntaxe špatné samo o sobě. Spíše by prý programátoři měli přemýšlet, jak nastavit barvy tak, aby je přirozeně povzbuzovaly ke psaní lepšího kódu. „Řada programátorů má kód plný neužitečných komentářů, protože komentáře jsou tak trochu skryté zelenou barvou,“ ukazuje třeba programátor James Fisher. „Ale když si nastavíte jako barvu pro komentáře svítivou červenou, najednou vás trkne, jak je ten kód ohavný. A to je dobře, že vypadá ohavně. To vás donutí napsat přehledný a lepší kód.“

Vadí mu také, že barva pro odstranění je obvykle červená, zatímco barva pro přidání nového textu (například v příspěvcích do kódu na GitHub) je zelená. „Naznačuje to, že více kódu je dobře, zatímco odstraňování je nebezpečné,“ říká Fisher. „Podle mých zkušeností je to často naopak.“

Programátor si může zvýrazňování syntaxe nejen vypnout/zapnout, ale také do detailů přizpůsobit svým představám a stylu práce

Otázka tedy zřejmě nezní, zda syntaxi zvýrazňovat, ale zda programátoři tuší, jak zvýrazňování syntaxe ovlivňuje jejich návyky, například právě při zacházení s komentáři. Vědecká studie potvrzuje, že okamžitá zpětná vazba programovacího prostředí snižuje počet chyb a zvyšuje porozumění tomu, co se děje, zejména u začínajících programátorů.

Zvýrazňování syntaxe je navíc možná zavádějící výraz. „Mělo by se tomu říkat ‚skrývání syntaxe‘, protože nejužitečnější pro mě je, že obarvený text nemusím číst a přesto rychle pochytím, jaký má pro kód význam,“ komentuje jeden z programátorů na Hacker News. Mezi programátory je to každopádně oblíbené téma k diskuzi, i když v této otázce mají povětšinou jasno.

Autor:
Témata: software
  • Nejčtenější

V noci na pondělí přinese prach z Halleyovy komety nebeskou podívanou

v diskusi je 7 příspěvků

5. května 2024

Meteorický roj Eta-Aquaridy je jedním ze dvou, jehož původ můžeme spojit se slavnou Halleyovou...

Jak mohou být tak levná? Výborně hrající sluchátka lze koupit „za hubičku“

v diskusi je 10 příspěvků

3. května 2024

Premium Milovníci kvalitně reprodukované hudby mohou za sluchátka utratit spoustu peněz a nelitovat toho,...

{NADPIS reklamního článku dlouhý přes dva řádky}

{POPISEK reklamního článku, také dlouhý přes dva a možná dokonce až tři řádky, končící na tři tečky...}

Malý bojovník na Měsíci zvládl, co se nečekalo. Přežil tamní kruté noci

v diskusi jsou 2 příspěvky

3. května 2024  14:32

Japonské zařízení Smart Lander for Investigating Moon (SLIM) bylo prvním, které letos úspěšně...

Štefánikova tragická smrt i po pěti letech budila v Československu emoce

v diskusi je 20 příspěvků

4. května 2024

Československo si před 100 lety, 4. května 1924, připomnělo páté výročí tragické smrti jednoho ze...

{NADPIS reklamního článku dlouhý přes dva řádky}

{POPISEK reklamního článku, také dlouhý přes dva a možná dokonce až tři řádky, končící na tři tečky...}

KVÍZ: Připomeňme si květnové povstání a konec druhé světové války v Evropě

v diskusi je 15 příspěvků

5. května 2024

Výročí květnového povstání v Českých zemích a konec druhé světové války v Evropě si připomeneme...

Apple možná připravuje překvapení. V úterý by mohl ukázat nový čip

v diskusi nejsou příspěvky

6. května 2024

Apple v úterý v 16:00 středoevropského letního času začne představovat řadu novinek v rámci akce...

KOMENTÁŘ: Zbraň na AI? Proti strojům lze postavit kolektivní superinteligenci

v diskusi je 5 příspěvků

5. května 2024

Premium Státy pokulhávají za vědou a technikou ve snaze regulovat umělou inteligenci. Stroje přitom mají...

Litevci, Poláci nebo Hitler? Baltské mocnosti se přetahovaly o Memel

v diskusi jsou 3 příspěvky

5. května 2024

Květen 1924 přinesl diplomatické vítězství Litevců nad Poláky. Svět jim přiklepl původně německý...

V noci na pondělí přinese prach z Halleyovy komety nebeskou podívanou

v diskusi je 7 příspěvků

5. května 2024

Meteorický roj Eta-Aquaridy je jedním ze dvou, jehož původ můžeme spojit se slavnou Halleyovou...

V 59 letech zemřela herečka Simona Postlerová, ještě v sobotu zkoušela

Zemřela divadelní a filmová herečka Simona Postlerová, bylo jí 59 let. Zprávu o úmrtí potvrdil nadační fond Dvojka...

Dara Rolins je po další plastice. Kritiku fanoušků nechápe, cítí se svěží

Zpěvačka Dara Rolins (51) se na čas stáhla z veřejného života. V tom období prodělala „estetický zákrok“ a na sociální...

Titěrné sukně i míčky na podpatcích. Zendaya vzkřísila trend tenniscore

S nadsázkou bychom mohli říct, že největší tenisovou událostí tohoto roku je premiéra snímku Rivalové. Aspoň co se módy...

Je to šílený, hodnotily firmy práci řemeslníků, kteří opravili střechu

Po zimě se často ukážou mnohé „vady na kráse“ domu, střechy nevyjímaje. Někdy nezbývá nic jiného než kompletní výměna....

Ukradené auto s AirTagem si našel, ale od policie dostal vynadáno

Vyjít ráno před dům a nenajít tam svůj vůz je noční můrou každého majitele. Do takové nezáviděníhodné situace se dostal...