ASCII (англ. American Standard Code for Information Interchange, [ˈæs.ki][1]) — стандарт кодирования букв латинского алфавита, цифр, некоторых специальных знаков и управляющих последовательностей, принятый в 1963 году Американской ассоциацией стандартов как основной способ представления текстовых данных в ЭВМ[2].
ASCII | |
---|---|
Орган стандартизации | Национальный институт стандартов США |
Медиафайлы на Викискладе |
Описание
правитьСтандарт ASCII представляет собой 7-битный код без рекомендаций относительно контроля чётности, содержащий 27 = 128 кодовых позиций[3], в которых размещены следующие символы:
История
правитьС развитием вычислительной техники и языков программирования возможностей телетайпного кода ITA2 стало не хватать, что вынуждало производителей ЭВМ создавать расширения для ITA2 или же свои собственные коды. Кроме того, для записи на перфокарты использовались различные варианты кода Холлерита. Таким образом, к началу 1960-х годов существовало достаточно большое количество кодировок латиницы, используемых как для передачи по линиям связи, так и для записи на магнитную ленту, перфоленту и перфокарты, — таких как ITA2, FIELDATA[англ.], различные варианты BCDIC и т. д.[4], причём даже в рамках одной и той же кодировки один код мог соответствовать различным символам в зависимости от модели и назначения устройства. Чтобы решить эту проблему, 4 августа 1960 года был создан комитет X3.2 (как часть комитета X3, сформированного 13 января того же года)[5], в который вошли представители компаний IBM (в частности, Роберт Бемер[англ.]), AT&T, Bell Labs и других.
Работа по созданию ASCII началась 6 октября 1960 года[5], и почти 3 года спустя, 17 июня 1963 года, была опубликована её первая редакция (ASA X3.4-1963)[6]. В ней отсутствовали строчные буквы, а область из 28 позиций в колонках (группах по 16 символов) № 6 и № 7 (считая с 0) была зарезервирована для дальнейшего использования[7][8]. Велись споры о том, использовать эту область для добавления строчных букв или же управляющих символов.
В 1965 году была подготовлена новая редакция ASCII (ASA X3.4-1965), которая, однако, так и не была опубликована и не использовалась нигде, кроме терминалов IBM 2260/2848 и принтеров IBM 1053 (да и то без строчных букв и некоторых других символов)[9]. Следующая редакция ASCII (USAS X3.4-1967) была опубликована 5 июля 1967 года и определила окончательную кодовую таблицу[10]. Новые редакции ASCII продолжили выходить и далее (USAS X3.4-1968, ANSI X3.4-1977, ANSI X3.4-1986 и т. д.), однако кодовую таблицу изменения в них более не затрагивали.
В целом, внедрение ASCII долгое время саботировалось компанией IBM, отдававшей предпочтение собственной кодировке EBCDIC, являющейся дальнейшим развитием кодировки BCDIC, также созданной IBM и основанной, в свою очередь, на коде Холлерита[6].
Структурные свойства таблицы
правитьПервая редакция ASCII содержала 36 управляющих символов, 10 арабских цифр, 26 заглавных латинских букв и 27 специальных символов, которые подразделяли на группы[11]:
- 8 знаков препинания (
.
,,
,:
,;
,!
,?
,'
,"
); - 5 знаков для финансовых и биржевых операций (
#
,$
,%
,&
,@
); - 2 пары скобок (
(
,)
,[
,]
); - 8 математических символов (
+
,-
,*
,/
,\
,=
,<
,>
)[12]; - 2 стрелки для блок-схем: (
↑
,←
).
Cимвол «подушка» (⌑
), имевшийся в наборе доступных символов многих печатающих устройств того времени и присутствовавший в кодировках BCDIC, FIELDATA и т. д., ни в одну из редакций ASCII не вошёл.
В редакции 1967 года был пересмотрен набор управляющих символов (сокращён до 33), убраны стрелки, но добавлены строчные буквы и 7 дополнительных символов (^
, _
, `
, {
, |
, }
, ~
), после чего кодовая таблица приняла окончательный вид[13]:
.0 | .1 | .2 | .3 | .4 | .5 | .6 | .7 | .8 | .9 | .A | .B | .C | .D | .E | .F | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0. | NUL | SOH | STX | ETX | EOT | ENQ | ACK | BEL | BS | HT | LF | VT | FF | CR | SO | SI |
1. | DLE | DC1 | DC2 | DC3 | DC4 | NAK | SYN | ETB | CAN | EM | SUB | ESC | FS | GS | RS | US |
2. | ! | " | # | $ | % | & | ' | ( | ) | * | + | , | - | . | / | |
3. | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | : | ; | < | = | > | ? |
4. | @ | A | B | C | D | E | F | G | H | I | J | K | L | M | N | O |
5. | P | Q | R | S | T | U | V | W | X | Y | Z | [ | \ | ] | ^ | _ |
6. | ` | a | b | c | d | e | f | g | h | i | j | k | l | m | n | o |
7. | p | q | r | s | t | u | v | w | x | y | z | { | | | } | ~ | DEL |
Все символы в ASCII делятся на 4 группы по 32 символа[14]:
- Управляющие символы (
0x00
…0x1F
) — предназначены для управления передачей и выводом текста на терминал[15]. Группа начинается символом NUL (0x00
), означающим незаписанный участок, например, перфоленты, и этот символ должен игнорироваться при выводе на экран или на печать[16]. За пределами группы, в конце таблицы также располагается символ DEL0x7F
— участок перфоленты, пробитый целиком, означающий, что символ, который здесь располагался, был удалён, а значит, его также следует пропустить[16][17];- Сами управляющие символы основной группы изначально были разделены на 4 подгруппы: управление передачей (
0x01
—0x07
), форматирование (0x08
—0x0F
), управление устройством (0x10
—0x17
) и разделители потоков данных (0x18
—0x1F
)[18]. В редакции 1967 года этот порядок был отчасти нарушен из-за переноса дополнительных управляющих символов.
- Сами управляющие символы основной группы изначально были разделены на 4 подгруппы: управление передачей (
- Группа цифр и основных знаков препинания — делится на две подгруппы, соответствующие верхнему и нижнему регистру.
- Группа начинается с пробела
0x20
— было принято решение, что пробел должен считаться печатным, а не управляющим символом, но при этом располагаться в самом начале — для корректной работы алгоритмов сортировки[19]; - Цифры идут во второй подгруппе — такое решение было принято для того, чтобы их легко было преобразовать в двоично-десятичный код, убрав старшие 4 бита, и обратно, прибавив префикс 00112: например, цифра 5 имеет код 0011 01012. По этой причине цифры невозможно было разместить в первой подгруппе, так как в ней первым идёт пробел[20]. Другая причина расположения цифр в этой группе — было необходимо, чтобы при сортировке большинство знаков препинания располагались раньше цифр и букв[21];
- 9 символов после пробела — знаки препинания (
!
,"
,#
,$
,%
,&
,'
,(
,)
), идущие в том порядке, в котором их располагали на пишущих машинках тех лет[11], за исключением скобок, которые располагались на позициях0x28
и0x29
, так как цифра 0 оказалась под кодовой позицией пробела[22]. Однако на электромеханических пишущих машинах, в частности IBM Selectric расположение этих знаков было иным, что связано с наличием у некоторых из них механизма дозирования силы удара, который требовал расположения на одной клавише знаков, близких по оптической плотности. Окончательно отличное от таблицы ASCII положение этих знаков было закреплено в IBM PC. - Символы точки и запятой в пишущих машинках тех лет дублировались в обоих регистрах. В ASCII было решено не дублировать знаки, а заполнить освободившееся место символами
<
и>
[23]. Знак вопроса также спарен со знаком косой черты как на пишущих машинках[11].
- Группа начинается с пробела
- Группа заглавных букв начинается с символа «коммерческое „эт“» (@,
0x40
) — предполагалось, что для машин, поставляемых во Францию и Италию, этот символ будет заменяться на буквуÀ
. Положение заглавных латинских букв и цифр было выбрано из соображений совместимости с шестибитной кодировкой DEC SIXBIT. Три позиции после заглавных букв (0x5B
,0x5C
и0x5D
) также предполагалось при необходимости заменять на национальные символы. - Группа строчных букв появилась в ASCII-1965, но была пересмотрена в ASCII-1967. Все строчные буквы расположены так же, как в соответствующие заглавные, что позволяет переключать регистр, изменяя лишь старший бит. Позиции
0x60
,0x7B
,0x7C
и0x7D
также предполагалось при необходимости заменять на национальные символы. В редакции 1965 года был добавлен символ логического отрицания (¬,0x7C
), который в редакции 1967 года был убран.
Важная особенность — ASCII, в отличие, к примеру, от ITA2, не использует переключение регистров[21]. Хотя переключение регистров для заглавных букв могло бы уменьшить требуемое количество бит и, соответственно, увеличить скорости передачи и уменьшить требуемое место на носителях, оно также повысило бы риск не прочесть сообщение при его повреждении[24]. Таким образом, было решено отказаться от использования регистров и уместить все символы в 7 бит[21]. Тем не менее, для возможности дальнейшего расширения в набор включены символы ESC, SI и SO[24].
Наложение символов
правитьС помощью символа Backspace (BS) (возврат на один символ) на принтере можно печатать один символ поверх другого. В ASCII таким же способом можно добавить к буквам диакритические знаки, например:
a BS '
→ áa BS `
→ àa BS ^
→ âo BS /
→ øc BS ,
→ çn BS ~
→ ñ
Примечание. В старых шрифтах апостроф (') рисовался с наклоном влево (сравните: «'» и «´»), а тильда (~) была сдвинута вверх (сравните: «~» и «˜»), так что они как раз подходили на роль символов акут (´) и «тильда сверху» (˜).
Если в одной позиции дважды напечатать один и тот же символ, получится жирный символ; если в одной позиции напечатать символ и подчёркивание (_), получится подчёркнутый символ:
a BS a
→ aa BS _
→ a
Эта техника до сих пор используется, например, в справочной системе man.
Национальные варианты ASCII
правитьСтандарт ISO 646 (ECMA-6) предусматривает возможность размещения в ASCII национальных символов. Для этого предлагается заменять символы «@», «[», «\», «]», «^», «`», «{», «|», «}», «~». Также на месте знака решётки (#) может быть размещён символ фунта (£), а на месте символа доллара ($) — знак валюты (¤). Вариант ASCII, не содержащий национальных символов, называется US-ASCII или ISO 646 IRV (International Reference Version с англ. — «международная ссылочная версия»).
Для некоторых языков с нелатинской письменностью (русского, греческого, арабского, иврита и др.) существовали более радикальные модификации ASCII:
- в одних на месте строчных латинских букв размещались национальные символы (для русского (КОИ-7 Н2) и греческого вариантов — заглавные буквы);
- в других предусматривалось переключение между US-ASCII и национальным вариантом «на лету» с помощью символов SO и SI; в этом случае в национальном варианте можно было полностью заменить латинские буквы на национальные символы (как, например, в КОИ-7 Н1).
Со временем стали появляться производные 8-битные кодировки (кодовые страницы), содержащие 28 = 256 кодовых позиций, в которых нижняя половина кодовой таблицы (позиции 0x00
—0x7F
) совпадает с US-ASCII, а верхняя (позиции 0x80
—0xFF
) служит для размещения дополнительных, в том числе национальных, символов. Подобные ASCII-совместимые кодировки, получившие неофициальное собирательное название «Расширенная ASCII[англ.]», оказались удобнее упомянутых ранее 7-битных модификаций и широко использовались вплоть до начала повсеместного внедрения Юникода. Впрочем, отсутствие единого стандарта размещения национальных символов в их кодовых таблицах (например, кириллицы в КОИ-8, Windows-1251, ISO 8859-5 и т. д.) доставляло множество проблем. Так, например, когда почтовые клиенты отправителя и получателя использовали различные кодировки для интерпретации электронного письма, его текст (за исключением символов ASCII) становился нечитаемым.
Первые 128 символов Юникода совпадают с соответствующими символами US-ASCII.
В первой редакции стандарта ASCII (1963 год) в позициях 0x5E
и 0x5F
располагались, соответственно, символы «стрелка вверх» (↑) и «стрелка влево» (←). Стандарт ECMA-6 (1965 год) заменил их, соответственно, на карет (^) и подчёркивание (_).
В Советском Союзе стандарт был утверждён в ГОСТ 27463-87 (СТ СЭВ 356-86) в виде таблицы международной ссылочной версии как КОИ-7 Н0[25].
Управляющие символы
правитьСтандарт ASCII создавался не только для применения в ЭВМ, но и для обмена информацией по телетайпу. В набор были включены непечатаемые символы, используемые как команды для управления телетайпом. Аналогичные команды применялись и в других докомпьютерных средствах обмена сообщениями (азбука Морзе, семафорная азбука), учитывая специфику устройства. Большинство управляющих символов ASCII вскоре утратили своё назначение и в современных компьютерных системах не используются.
- NUL,
0x00
(null с англ. — «пустой»). СимволNUL
всегда игнорировался. На перфолентах бит «1» обозначался отверстием, а бит «0» — отсутствием отверстия. Участки перфоленты, на которых не была записана информация, не содержали отверстий (то есть содержали символыNUL
); такие участки располагались в начале и в конце ленты. СимволNUL
по сей день используется во многих языках программирования (как признак конца строки) и обозначается как\0
(термин «строка» обозначает последовательность символов). В некоторых операционных системахNUL
— последний символ любого текстового файла.
Сообщения, передаваемые по каналу связи, делились на две части:
- Заголовок;
- Текст.
«Заголовок» содержал: адреса отправителя и получателя, контрольную сумму и т. п.; мог размещаться до «текста» или после. Термином «текст» называлась часть сообщения, предназначенная для печати.
Символ | Код HEX | Расшифровка | Перевод | Описание |
---|---|---|---|---|
SOH | 0x01
|
start of heading | начало «заголовка» | Символ начала заголовка (SOH ) отмечает разделение данных, не относящийся к данным: часть потока, содержащую адреса и другие служебные данные.
|
STX | 0x02
|
start of text | начало «текста» | Включить печатающее устройство (телетайп). Текст для печати располагался между символами STX и ETX .
|
ETX | 0x03
|
end of text | конец «текста» | Выключить печатающее устройство (телетайп). В наши дни символ ETX используется для отправки процессу сигнала SIGINT (signal interrupt с англ. — «сигнал-прерывание») и может быть набран нажатием комбинации клавиш Ctrl+C. Получив такой сигнал, процесс должен завершить работу[англ.].
|
EOT | 0x04
|
end of transmission | конец передачи | Символ используется эмуляторами терминалов в значении «Конец файла» (EOF: англ. end of file) и может быть отправлен нажатием комбинации клавиш Ctrl+D. Получив такой сигнал, эмулятор терминала определит процесс, который в данный момент работает с терминалом, и установит в стандартном потоке ввода этого процесса (stdin: англ. standard input stream) флаг «Конец файла». В результате процесс прекратит чтение[англ.] stdin и начнёт обработку прочитанных данных. |
ENQ | 0x05
|
enquiry | «Прошу подтверждения!» | |
ACK | 0x06
|
acknowledgement | «Подтверждаю!» | Символ NAK означает обратное: «Не подтверждаю!».
|
BEL | 0x07
|
bell | звуковой сигнал: звонок | Используется для подачи звукового сигнала.
Во многих языках программирования обозначается как |
BS | 0x08
|
backspace | возврат на один символ | Передаётся при нажатии клавиши ← Backspace.
Во многих языках программирования обозначается как |
HT | 0x09
|
horizontal tab | горизонтальная табуляция | Во многих языках программирования обозначается как \t .
|
LF | 0x0A
|
line feed | перевод строки | Команда для опускания каретки печатающего устройства на одну строку вниз. Обозначение конца строки различается в семействах операционных систем:
Многие терминалы 1970—1980-х годов содержали переключатель поведения клавиши ↵ Return, позволяющий посылать при нажатии на неё либо последовательность Во многих языках программирования обозначается как |
VT | 0x0B
|
vertical tab | вертикальная табуляция | Во многих языках программирования обозначается как \v .
|
FF | 0x0C
|
form feed | «прогон страницы», новая страница | Команда для принтера: продолжить печать с начала следующего листа.
Во многих языках программирования обозначается как |
CR | 0x0D
|
carriage return | возврат каретки | Команда для принтера: продолжить печать с начала текущей строки (не с новой строки). В классических версиях операционной системы Mac OS символ CR обозначал конец строки текстового файла. С клавиатуры символ CR может быть введён нажатием комбинации клавиш: Ctrl+M.
Во многих языках программирования обозначается как |
SO | 0x0E
|
shift out | «Переключиться на другую ленту (кодировку)» | Другая лента обычно была окрашена в красный цвет. В дальнейшем символ использовался для переключения на национальную кодировку. |
SI | 0x0F
|
shift in | «Переключиться на исходную ленту (кодировку)» | Команда для выполнения действия, обратного действию SO .
|
DLE | 0x10
|
data link escape | «Экранирование канала данных» | Любые символы, следующие после DLE , должны восприниматься как данные, а не как управляющие символы.
|
DC1 | 0x11
|
device control 1 | Первый символ управления устройством | Команда включить устройство чтения перфоленты. |
DC2 | 0x12
|
device control 2 | Второй символ управления устройством | Команда включить перфоратор. |
DC3 | 0x13
|
device control 3 | Третий символ управления устройством | Команда выключить устройство чтения перфоленты. |
DC4 | 0x14
|
device control 4 | Четвёртый символ управления устройством | Команда выключить перфоратор. |
NAK | 0x15
|
negative acknowledgement | «Не подтверждаю!» | Обратно символу ACK .
|
SYN | 0x16
|
synchronous idle | синхронное ожидание | Этот символ передавался, когда (для синхронизации) было необходимо что-нибудь передать. |
ETB | 0x17
|
end of transmission block | конец блока передаваемых данных | Иногда данные (по техническим причинам) разбивались на блоки. |
CAN | 0x18
|
cancel | «Отмена» | Отмена того, что было передано ранее. |
EM | 0x19
|
end of medium | «Конец носителя» | Кончилась бумага, перфолента, магнитная лента и т. п. |
SUB | 0x1A
|
substitute | «Подставить» | Символ ставится:
В настоящее время символ вставляется нажатием комбинации клавиш Ctrl+Z и используется для обозначения конца файла в операционных системах DOS и Windows. |
ESC | 0x1B
|
escape | Знак того, что символ, следующий после ESC , имеет какое-то другое (отличное от определённого в ASCII) значение. Обычно после символа ESC следуют управляющие последовательности; в операционной системе DOS они реализуются драйвером ANSI.SYS.
| |
DEL | 0x7F
|
delete | стереть последний символ | Символом DEL (состоящим в двоичном коде из всех единиц) можно было «забить» любой символ. Устройства и программы игнорировали DEL так же, как и NUL .
Код этого символа происходит из первых текстовых процессоров с памятью на перфоленте: в них удаление символа происходило «забиванием» его кода отверстиями (обозначавшими логические единицы). |
Поддерживалось разделение данных на 4 уровня:
Символ | Код | Расшифровка | Перевод | Описание |
---|---|---|---|---|
FS | 0x1C
|
file separator | разделитель файлов | сообщение могло состоять из файлов |
GS | 0x1D
|
group separator | разделитель групп | файлы могли состоять из групп |
RS | 0x1E
|
record separator | разделитель записей | группы могли состоять из записей |
US | 0x1F
|
unit separator | разделитель полей | записи могли состоять из полей |
Представление ASCII в ЭВМ
правитьНа подавляющем большинстве современных компьютеров минимально адресуемой единицей памяти является 8-битный байт (октет), поэтому там используются 8-битные, а не 7-битные символы. Обычно символ ASCII расширяют до 8 бит, просто добавляя один нулевой бит в качестве старшего.
USASCII-8
правитьНа компьютерах IBM/360 применялся другой метод: 6-й бит (если первым считать самый младший бит) перемещается в 7-й, а бывший 7-й «раздваивается» и копируется и в 8-й бит, и в 6-й[26]. Такую кодировку называли USASCII-8[27]
.0 | .1 | .2 | .3 | .4 | .5 | .6 | .7 | .8 | .9 | .A | .B | .C | .D | .E | .F | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0. | NUL | SOM | EOA | EOM | EQT | WRU | RU | BELL | BKSP | HT | LF | VT | FF | CR | SO | SI |
1. | DC0 | DC1 | DC2 | DC3 | DC4 | ERR | SYNC | LEM | S0 | S1 | S2 | S3 | S4 | S5 | S6 | S7 |
2. | ||||||||||||||||
3. | ||||||||||||||||
4. | BLANK | ! | " | # | $ | % | & | ' | ( | ) | * | + | , | - | . | / |
5. | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | : | ; | < | = | > | ? |
6. | ||||||||||||||||
7. | ||||||||||||||||
8. | ||||||||||||||||
9. | ||||||||||||||||
A. | @ | A | B | C | D | E | F | G | H | I | J | K | L | M | N | O |
B. | P | Q | R | S | T | U | V | W | X | Y | Z | [ | \ | ] | ↑ | ← |
C. | ||||||||||||||||
D. | ||||||||||||||||
E. | a | b | c | d | e | f | g | h | i | j | k | l | m | n | o | |
F. | p | q | r | s | t | u | v | w | x | y | z | ESC | DEL |
На компьютерах с минимально адресуемой единицей памяти в 36 бит поначалу использовали 6-битные символы (1 слово = 6 символов). После перехода на ASCII на таких компьютерах в одном слове стали размещать либо 5 семибитных символов (1 бит оставался лишним), либо 4 девятибитных символа.
Ввод с клавиатуры
правитьРасположение символов ASCII на клавиатуре согласно ANSI X4.14-1971: символы верхнего регистра вводятся в сочетании с клавишей ⇧ Shift, а управляющие символы — с Ctrl[28].
1
2
3
4
5
6
7
8
9
0
-
^
\
q
w
e
r
t
y
u
i
o
p
@
[
␡
a
s
d
f
g
h
j
k
l
;
:
]
z
x
c
v
b
n
m
,
.
/
Коды ASCII используются в программировании как промежуточные кроссплатформенные коды нажатых клавиш (в противовес скан-кодам IBM PC и прочим внутренним кодам). Для раскладки клавиатуры QWERTY таблица кодов выглядит так, как показано в следующей таблице[29].
См. также
правитьПримечания
править- ↑ ASCII (англ.). the Cambridge English Dictionary. dictionary.cambridge.org. Дата обращения: 9 апреля 2018. Архивировано 27 сентября 2017 года.
- ↑ Mackenzie, 1980, p. 211.
- ↑ Иллингуорт, 1990, с. 28.
- ↑ Mackenzie, 1980, p. 61.
- ↑ 1 2 Fischer, 2000, p. 11.
- ↑ 1 2 Fischer, 2000, p. 21.
- ↑ Mackenzie, 1980, p. 66.
- ↑ Mackenzie, 1980, p. 245—246.
- ↑ Mackenzie, 1980, p. 423—428.
- ↑ Fischer, 2000, p. 28.
- ↑ 1 2 3 Mackenzie, 1980, p. 240.
- ↑ вместо специального знака для операций умножения и деления было решено использовать типографский астериск и косую черту
- ↑ Mackenzie, 1980, p. 246—247.
- ↑ Mackenzie, 1980, p. 237.
- ↑ Mackenzie, 1980, p. 234.
- ↑ 1 2 Mackenzie, 1980, p. 235.
- ↑ Mackenzie, 1980, p. 225.
- ↑ Mackenzie, 1980, p. 226.
- ↑ Mackenzie, 1980, p. 222—224.
- ↑ Mackenzie, 1980, p. 225,239.
- ↑ 1 2 3 Mackenzie, 1980, p. 236.
- ↑ Mackenzie, 1980, p. 241.
- ↑ Mackenzie, 1980, p. 240—241.
- ↑ 1 2 Mackenzie, 1980, p. 214—215.
- ↑ ГОСТ 27463-87 (СТ СЭВ 356-86) Системы обработки информации. 7-битные кодированные наборы символов (с Изменением N 1), ГОСТ от 29 октября 1987 года №27463-87 . docs.cntd.ru. Дата обращения: 9 апреля 2018. Архивировано 23 апреля 2018 года.
- ↑ Amdahl G. M., Blaauw G. A., Brooks F. P., Jr. «Architecture of the IBM system/360». 1964
- ↑ Mackenzie, 1980, p. 399—400.
- ↑ ANSI X4.14-1971: Alphanumeric Keyboard Arrangements Accommodating the Character Sets of ASCII and ASCSOCR (англ.)
- ↑ Keys Enum . Microsoft.com. Дата обращения: 11 июня 2022. Архивировано 11 июня 2022 года.
Литература
править- American Standard Code for Information Interchange, ASA X3.4-1963
- USA Standard Code for Information Interchange, USAS X3.4-1967
- USA Standard Code for Information Interchange, USAS X3.4-1968
- American National Standard Code for Information Interchange ANSI X3.4-1977
- 7-Bit American National Standard Code for Information Interchange (7-Bit ASCII), ANSI X3.4-1986
Ссылки
править- Charles E. Mackenzie. Coded Character Sets, History and Development (англ.). — Addison-Wesley Publishing Company, inc, 1980. — ISBN 0-201-14460-3.
- Fischer, Eric The Evolution of Character Codes, 1874–1968 (англ.) 14–15 (Table 35) (20 июня 2000). Дата обращения: 30 ноября 2022. Архивировано 30 ноября 2022 года.
- Толковый словарь по вычислительным системам / Под редакцией В. Иллингуорта и др.: Пер. с английского А.К. Белоцкого и др.; Под редакцией Е.К. Масловского. — М.: Машиностроение, 1990. — ISBN 5-217-00617-X.
- Standard ECMA-6: 7-bit coded character set. 6th edition (англ.). Ecma international (декабрь 1991). Архивировано 23 августа 2011 года.
- Tom Jennings. An annotated history of some character codes or ASCII. American standard code for information infiltration (англ.) (29 октября 2004). Архивировано 17 июля 2011 года.
- ASCII chart and other resources (англ.). JimPrice.Com.