Premium

Získejte všechny články
jen za 89 Kč/měsíc

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ší

Námořníci USA propašovali před 100 lety na palubu bitevní lodi prostitutku

v diskusi je 30 příspěvků

13. dubna 2024

V dubnu 1924 zažilo americké námořnictvo obrovský skandál, který se dostal na titulní stránky...

Uvidíme v budoucnu na obloze druhý Měsíc? Příčinou může být neobvyklá hvězda

v diskusi je 13 příspěvků

17. dubna 2024

Velmi neobvyklá hvězda éta Carinae v 19. století náhle zjasnila a stala se druhou nejjasnější...

{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...}

Skvělý filmový zvuk bez velké instalace. Test nejzajímavějších soundbarů

v diskusi je 17 příspěvků

15. dubna 2024

Položíte jej na polici před televizor, propojíte kabelem, zapojíte do zásuvky a během pár chvil se...

Dawesův plán na čas stabilizoval Německo, ale nástup Hitlera neodvrátil

v diskusi je 15 příspěvků

16. dubna 2024

Německá vláda přijala před 100 lety, v dubnu 1924, Dawesův plán. Byl to americký projekt na...

{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...}

Patnáct zbytečných obětí. Před 100 lety vybuchl důl Gabriela na Ostravsku

v diskusi jsou 4 příspěvky

12. dubna 2024

Dvanáctý duben 1924 přinesl vážnou důlní katastrofu v Československu. Výbuch v dole Gabriela v...

Znovuzrození japonských letadlových lodí. Ve výzbroji budou mít F-35B

v diskusi je 1 příspěvek

19. dubna 2024

Japonsko má ve své ústavě zakázáno vlastnit ofenzivní zbraně, jako jsou letadlové lodě. Doba...

Lotyšská armáda je malá, materiálem nehýří, ale Ukrajině něco ze svého poslala

v diskusi je 5 příspěvků

18. dubna 2024

V roce 2004 vstoupilo Lotyšsko do NATO, přesto nemůže nechat svou případnou obranu pouze na bedrech...

Pes na Měsíci či Marsu už nemusí být fikce. NASA trénuje průzkumného robopsa

v diskusi jsou 2 příspěvky

17. dubna 2024  15:12

Vědci z projektu Lassie, sponzorovaném americkou NASA, zdokonalují robotického psa pro použití při...

Na dům mu spadl odpad z vesmíru. Nyní NASA potvrdila, že je to kus z baterie

v diskusi je 7 příspěvků

17. dubna 2024  11:50

Před několika týdny proběhla médii informace o varování německého Spolkového úřad pro civilní...

Náhle zemřel zpěvák Maxim Turbulenc Daniel Vali, bylo mu 53 let

Ve věku 53 let zemřel zpěvák skupiny Maxim Turbulenc Daniel Vali. Letos by se svou kapelou oslavil 30 let na scéně....

Sexy Sandra Nováková pózovala pro Playboy. Focení schválil manžel

Herečka Sandra Nováková už několikrát při natáčení dokázala, že s odhalováním nemá problém. V minulosti přitom tvrdila,...

Charlotte spí na Hlaváku mezi feťáky, dluží spoustě lidí, říká matka Štikové

Charlotte Štiková (27) před rokem oznámila, že zhubla šedesát kilo. Na aktuálních fotkách, které sdílela na Instagramu...

Vykrojené trikoty budí emoce. Olympijská kolekce Nike je prý sexistická

Velkou kritiku vyvolala kolekce, kterou pro olympijský tým amerických atletek navrhla značka Nike. Pozornost vzbudily...

Rohlík pro dítě, nákup do kočárku. Co v obchodě projde a kdy už hrozí právník?

V obchodech platí pravidla, která občas zákazník nedodržuje. Někdy se navoní parfémem, aniž by použil tester, nebo...