ASCII

Technology
12 hours ago
8
4
2
Avatar
Author
Albert Flores

Stránka ASCII na české Wikipedii poskytuje informace o souboru ASCII (American Standard Code for Information Interchange), což je standardní kódování znaků pro elektronickou komunikaci. Článek se zaměřuje na historii, vývoj a použití ASCII. Představuje také rozšíření ASCII, jako je například rozšířená ASCII a Unicode. Dále se také zabývá problémy spojenými s ASCII, jako je například omezený počet znaků a nekompatibilita s některými jazyky. Stránka obsahuje také ukázky ASCII grafiky a další zajímavosti spojené s tímto kódováním.

Mapa všech 128 ASCII znaků

ASCII je anglická zkratka pro American Standard Code for Information Interchange („americký standardní kód pro výměnu informací“). V podstatě jde o kódovou tabulku, která definuje znaky anglické abecedy a jiné znaky používané v informatice. +more Jde o historicky nejúspěšnější znakovou sadu, ze které vychází většina současných standardů pro kódování textu přinejmenším v euro-americké zóně.

Tabulka obsahuje tisknutelné znaky: písmena, číslice, jiné znaky (závorky, matematické znaky (+ - * / % atd. ), interpunkční znaménka ( . +more : ; atd. ), speciální znaky (@ $ ~ atd. )), a řídicí (netisknutelné) kódy, které byly původně určeny pro řízení periferních zařízení (např. tiskárny nebo dálnopisu).

Kód ASCII je podle původní definice sedmibitový, obsahuje tedy 128 platných znaků. Pro potřeby dalších jazyků a pro rozšíření znakové sady se používají osmibitová rozšíření ASCII kódu, která obsahují dalších 128 kódů. +more Takto rozšířený kód je přesto příliš malý na to, aby pojal třeba jen evropské národní abecedy - pro reprezentaci takových znaků se v současnosti používá Unicode kódování - historicky však pro potřeby jednotlivých jazyků byly vytvořeny různé kódové tabulky, kde však význam kódů nad 127 nebyl jednoznačný. Systém kódových tabulek pro národní abecedy (stejně tak jako Unicode) spravuje například organizace ISO.

Tabulka ASCII kódů

V první tabulce (kódy 0h až 1Fh) jsou řídicí kódy, speciální netisknutelné znaky, sloužící k řízení datového přenosu, k formátování tisku, případně k jiným účelům (např. escape se používal pro sekvence sloužící ke konfiguraci tiskárny). +more V druhé, třetí a čtvrté tabulce jsou běžné tisknutelné znaky.

Výjimkou je znak mezera na začátku druhé tabulky (decimální kód 32, hexadecimální 20h, zkratka SP) který může být počítán jak k řídicím, tak k tisknutelným znakům a řídicí znak DEL (decimální kód 127, hexadecimální 7Fh) na konci poslední tabulky. Tip: Tyto ASCII kódy se dají napsat v české klávesnici.

DecHexZkratka (anglicky)Význam (anglicky)
000NULNULL character
101SOHStart of Header
202STXStart of Text
303ETXEnd of Text
404EOTEnd of Transmission
505ENQEnquiry
606ACKAcknowledge
707BELBell
808BSBackspace
909HTHorizontal Tab
100aLFLine feed
110bVTVertical Tab
120cFFForm Feed
130dCRCarriage return
140eSOShift Out
150fSIShift In
1610DLEData Link Escape
1711DC1Device Control (XOn)
1812DC2Device Control
1913DC3Device Control (XOff)
2014DC4Device Control
2115NAKNegative Acknowledge
2216SYNSynchronous Idle
2317ETBEnd of Transmission Block
2418CANCancel
2519EMEnd of Medium
261aSUBSubstitute
271bESCEscape
281cFSFile Separator
291dGSGroup Separator
301eRSRecord Separator
311fUSUnit Separator
[wiki_table=bdef626e] [wiki_table=900d9497] [wiki_table=ab94681c]

Popis speciálních a řídicích znaků

Tyto neviditelné znaky byly určeny pro řízení dálnopisu nebo tiskárny, ale v současnosti se z nich využívá jen poměrně malá část. Nejčastěji používané speciální znaky jsou:

* SPC - space, mezera, „prázdný znak“ * HT - Horizontal Tab - tabulátor * LF - Line Feed - odřádkování * CR - Carriage Return - návrat vozíku

Ani pro používání těchto kódů neexistuje všeobecně přijímaný standard. Například unixové operační systémy včetně Linux a Apple Mac OS X používají pro odřádkování kód LF, systémy DOS a Windows používají kombinaci CR+LF, Apple systémy z období před Mac OS X používají kód CR. +more (viz Nový řádek).

Ostatní speciální znaky se používají například pro definici komunikačních protokolů při komunikaci mezi počítači. Zde je význam speciálních znaků podle původního standardu.

Fyzické ovládání zařízení

BS: Backspace (návrat o 1 znak zpět) * HT: Horizontal Tab (tabulátor) * LF: Line Feed (posun o 1 řádek dolů) * VT: Vertical Tab (vertikální tabulátor) * FF: Form Feed (posun na další stránku) * CR: Carriage Return (návrat tiskové hlavičky na začátek)

Fyzické ovládání zařízení: ostatní

BEL: Bell - zvonek * DC1, DC2, DC3, DC4: Device Controls - DC1 a DC3 se používají jako XON and XOFF v softwarovém handshakingu

Logické řízení komunikace

SOH: Start of Header - začátek hlavičky * STX: Start of Text - začátek textu * ETX: End of Text - konec textu * EOT: End of Transmission - konec vysílání * ENQ: Enquiry - dotaz (žádost o komunikaci) * ACK: Acknowledge - potvrzení (připravenosti ke komunikaci) * DLE: Data Link Escape - používá se pro kódování speciálních znaků * NAK: Negative Acknowledge - zamítnutí (žádosti o komunikaci) * SYN: Synchronous Idle * ETB: End of Transmission Block - konec přenosového bloku

Fyzické řízení komunikace

NUL: Null - „nic“ * DEL: Delete - smazání * CAN: Cancel - zrušení * EM: End of Medium - konec média * SUB: Substitute - substituce

Oddělovače informací

FS: File Separator - oddělovač souboru * GS: Group Separator - oddělovač skupiny * RS: Record Separator - oddělovač záznamu * US: Unit Separator - oddělovač jednotek

Rozšiřování kódu

SI: Shift In * SO: Shift Out

* ESC: Escape

Odvozená kódování

První verze znakové sady ASCII z roku 1963 se výrazně odlišovala od verze publikované v roce 1967 - neobsahovala malá písmena a některé řídicí znaky měly jiné významy nebo kódy.

Znaková sada ASCII z roku 1967 se stala základem většiny kódování znaků (význačnější výjimkou je kódování EBCDIC, které vyvinula firma IBM pro své sálové počítače přibližně ve stejné době, kdy vznikal kód ASCII). Představuje rozumný kompromis mezi minimalistickými sadami obsahujícími pouze písmena základní latinské abecedy, číslice a několik málo interpunkčních symbolů a bohatými znakovými sadami, jejichž příkladem je sada symbolů používaných programovacím jazykem APL.

Prvním směrem úprav ASCII bylo vytváření sedmibitových národních sad popsané v normách CCITT V. 3 (později CCITT nebo ITU-T +more50'>T. 50), ISO/IEC 646 a ECMA-6. Tyto sady také zaváděly mezinárodní abecedu jako mírně upravenou verzi verzi amerického ASCII kódování (nahrazením znaku dolar znakem měnové jednotky a znaku tilda nadtržítkem).

Čeština používá tolik znaků s diakritikou, že pro ni nebylo možné vytvořit sedmibitovou znakovou sadu podle ITU-T T. 50 nebo ISO-646. +more Pro výstup na tiskárny však bylo možné použít jiný postup popsaný v těchto normách - přetisk písmene jiným znakem, který vytváří diakritické znaménko; znak apostrof je použitelný jako čárka, znak nadtržítko (případně vlnovka) lze nouzově použít místo háčku.

Okolo roku 1980 se začínají ve větší míře používat a definovat osmibitové znakové sady. Tyto sady mají mnoho výhod, díky kterým se používaly přibližně tři desetiletí - umožňují vytvořit funkční národní prostředí pro jeden nebo několik jazyků, nemají velké nároky na systémové prostředky, identita jeden oktet = jeden znak = jedna tisková pozice zjednodušuje programování.

Problémem bylo, že mezinárodní normy pro osmibitové sady vznikly poměrně pozdě, takže mnoho dodavatelů software a hardware vytvořilo svoje vlastní sady, které často dosáhly většího rozšíření než mezinárodní normy. Existence nejméně šesti kódování češtiny vedla k problémům při komunikaci po síti a výměně dat. +more K dalším nevýhodám patří nemožnost používání jednoho kódování pro texty ve více jazycích a špatná podpora asijských jazyků. Snaha odstranit tyto nevýhody vedla k vytvoření jednotného standardu ISO/IEC 10646 - Unicode.

Většina osmibitových kódování používala pro prvních 128 kódů kód ASCII, případně jeho mezinárodní variantu. Rozšíření osmibitových kódování a zahájením práce na univerzální znakové sadě v roce 1991 vedlo k tomu, že do nových verzí mezinárodních standardů byla nakonec převzata sada ASCII bez jakýchkoli změn.

Většina kódování vzniklých po roce 1970 tak zahrnuje ASCII kód nebo jeho nějakou modifikaci. Poměrně časté je rozšíření kódování o semigrafické znaky, které se překrývají se znaky řídicími, systém pak může poskytovat dvě metody výpisu na obrazovku; jedna vypisuje semigrafické znaky, druhá interpretuje tytéž znaky jako řídicí. +more Další kódování z ASCII pouze volně vycházejí - mnoho kódování nedodržuje rozdělení na oblast řídicích a tisknutelných znaků, některá zachovávají pouze kódy písmen a číslic, případně některých speciálních znaků. Příkladem takových kódování je kódování Cork evropských fontů pro sázecí program TeX nebo sedmibitová abeceda pro GSM definovaná v GSM 03. 38.

Escape sekvence

Znak ESC (escape) se používá např. pro definici tzv. +more escape sekvencí používaných pro rozšíření ASCII kódu pro různé účely. Jeden nebo několik znaků následujících znak ESC nejsou interpretovány jako ASCII kódy, ale mohou mít speciální význam - například mohou definovat novou pozici kurzoru na obrazovce terminálu nebo mohou definovat velikost fontu používaného tiskárnou, přepnout tiskárnu ze znakového do grafického módu atd.

Organizace ANSI definovala sekvence určené pro ovládání znakových terminálů. Tyto sekvence zahrnují např. +more posun kurzoru na určitý řádek a sloupec obrazovky.

Faktickým standardem pro starší jehličkové tiskárny jsou escape sekvence používané firmou Epson.

Odkazy

Reference

Související články

Znaková sada * Unicode, UTF-8 * ASCII art * EBCDIC * Znaková sada ZX Spectrum

Externí odkazy

[url=https://web.archive.org/web/20160304174518/http://znakynaklavesnici.cz/ascii-tabulka/]ASCII tabulka a přehled znaků[/url]

Kategorie:Standardy Kategorie:Počítačová terminologie Kategorie:Kódování znaků Kategorie:Zkratky iniciálové - 5 znaků

5 min read
Share this post:
Like it 8

Leave a Comment

Please, enter your name.
Please, provide a valid email address.
Please, enter your comment.
Enjoy this post? Join Cesko.wiki
Don’t forget to share it
Top