Стандартная часть таблицы символов (ascii)

КС С КС С КС С КС С КС С КС С КС С КС С
    @ P ` p
! A Q a q
" B R b r
# C S c s
$ D T d t
§ % E U e u
& F V f v
' G W g w
( H X h x
) I Y i y
* : J Z j z
+ ; K [ k {
, < L \ l |
- = M ] m }
. > N ^ n ~
/ ? O _ o

Некоторые из вышеперечисленных символов имеют особый смысл. Так, например, символ с кодом 9 обозначает символ горизонтальной табуляции, символ с кодом 10 – символ перевода строки, символ с кодом 13 – символ возврата каретки.

Дополнительная часть таблицы символов

КС С КС С КС С КС С КС С КС С КС С КС С
А Р а р Ё
Б С б с ё
В Т в т Є
Г У г у є
Д Ф д ф Ї
Е Х е х ї
Ж Ц ж ц Ў
З Ч з ч ў
И Ш и ш °
Й Щ й щ
К Ъ к ъ ·
Л Ы л ы
М Ь м ь
Н Э н э ¤
О Ю о ю
П Я п я  


В таблицах обозначение КС означает "код символа", а С – "символ".

Приложение 2

Операции языка Си

Операции приведены в порядке убывания приоритета. Операции с разными приоритетами разделены чертой.

Опера­ция Краткое описание Использование Порядок выполнения
Унарные операции
. Доступ к члену объект . член Слева направо
-> Доступ к члену по указателю указатель -> член
[] Индексирование переменная[выражение]
() Вызов функции ID(список_выр.)
++ Постфиксный инкремент lvalue++ Справа налево
-- Постфиксный декремент lvalue--
sizeof Размер объекта или типа sizeof(выражение или тип)
++ Префиксный инкремент ++lvalue
-- Префиксный декремент --lvalue
~ Побитовое НЕ ~выражение
! Логическое НЕ !выражение
- Унарный минус -выражение
+ Унарный плюс +выражение
* Раскрытие указателя *выражение
& Адрес &выражение
() Приведение типа (тип)выражение
Бинарные и тернарная операции
* Умножение выражение * выражение Слева направо
/ Деление выражение / выражение
% Получение остатка выражение % выражение
+ Сложение выражение + выражение
- Вычитание выражение – выражение
<< Сдвиг влево выражение << выражение
>> Сдвиг вправо выражение >> выражение
< Меньше выражение < выражение
<= Меньше или равно выражение <= выражение
> Больше выражение > выражение
>= Больше или равно выражение >= выражение
== Равно выражение == выражение
!= Не равно выражение != выражение
& Побитовое И выражение & выражение
^ Побитовое исключающее ИЛИ выражение ^ выражение
| Побитовое ИЛИ выражение | выражение
&& Логическое И выражение && выражение
|| Логическое ИЛИ выражение || выражение
?: Условная операция (тернарная) выражение ? выражение : выражение
Опера­ция Краткое описание Использование Порядок выполнения
= Присваивание lvalue = выражение Справа налево
*= Умножение с присваиванием lvalue *= выражение
/= Деление с присваиванием lvalue /= выражение
%= Остаток от деления с присваиванием lvalue %= выражение
+= Сложение с присваиванием lvalue += выражение
-= Вычитание с присваиванием lvalue -= выражение
<<= Сдвиг влево с присваиванием lvalue <<= выражение
>>= Сдвиг вправо с присваиванием lvalue >>= выражение
&= Поразрядное И с присваиванием lvalue &= выражение
|= Поразрядное ИЛИ с присваиванием lvalue |= выражение
^= Поразрядное ИСКЛЮЧАЮ­ЩЕЕ ИЛИ с присваиванием lvalue ^= выражение
, Последовательное вычисление выражение, выражение Слева направо

Приложение 3

Возможности препроцессора и его вызов

Препроцессор, как мы уже знаем, это программа предварительной обра­­ботки исходного текста программы перед этапом компиляции. Чаще всего препроцессор автоматически вызывается на этапе компи­ля­ции, если в исходном тексте обнаружена хотя бы одна его директива.

Напомним, что признаком директивы препроцессора является символ # (обычно в начале строки). При необходимости продолжения директивы в следующей строке, текущую строку должен завершать символ '\'.

Возможности препроцессора языка C:

- лексемное замещение идентификаторов;

- макрозамещение;

- включение файлов исходного текста;

- условная компиляция;

- изменение нумерации строк и текущего имени файла.

Директивы лексемного замещения идентификаторов

Директива определения значения идентификатора:

#define ID строка

В результате каждое вхождение в исходный текст элемента «ID» заменяется на значение элемента «строка»:

#define L_bufs 2048

#define binary int

#define WAIT fflush(stdin); getch()

#define BEEP sound(800);\

delay(100);\

nosound()

Лексемное замещение весьма удобно для сокращения записи повторяю­щихся фрагментов теста и определения символических констант:

#define YES 1

#define NO 2

#define ESC 27

#define Enter 30

которые могут быть в дальнейшем использованы:

if (x==ESC) break;

BEEP;

return(YES);

Директива отмены

#undef ID

Далее по исходному тексту можно назначить новое значение такого идентификатора.

Макрозамещение

Макрозамещение - обобщение лексемного замещения посредством параметризации строки директивы define в виде:

#define ID(параметр1,... ) строка

здесь между элементом «ID» и открывающей скобкой пробелы не допускаются.

Такой вариант директивы define иногда называют макроопределением. Элемент «строка» обычно содержит параметры, которые будут заменены препроцессором фактическими аргументами так называемой макрокоманды, записываемой в формате:

ID(аргумент1,... )

Пример макроопределения и макрокоманд:

#define P(X) printf("\n%s",X)

. . .

char *x;

P(x); // Использование макроопределения P(X)

P(" НАЧАЛО ОПТИМИЗАЦИИ");

printf("\n%s",x); // Эквивалентные операторы

printf("\n%s"," НАЧАЛО ОПТИМИЗАЦИИ");

В строке макроопределений идентификаторы параметров сложных выра­же­ний рекомендуется заключать в круглые скобки:

#define МАХ(A,B) ((A)>(B)? (A):(B))

#define ABS(X) ((X)<0? –(X):(X))

Потребность в круглых скобках возникает при опасности искажения смысла вложенных выражений из-за действия правил приоритета операций. Пример искажения смысла операций:

#define BP(X) X*X

. . .

int x,y,z;

x=BP(y+z); « x=y+z*y+z; « x=y+(z*y)+z;

Очевидно, что ошибки будут и при следующих вариантах:

#define BP(X) (X*X)

#define BP(X) (X)*(X)

Безопасный вариант:

#define BP(X) ((X)*(X))

Иногда источником ошибок может быть символ «точка с запятой» в конце строки макроопределения:

#define BP(X) ((X)*(X));

. . .

int x,y,z;

x=BP(z)-BP(y); « y=((z)*(z)); -((y)*(y));

Макроопределение отменяется директивой undef.

Идентификаторы макроопределений обычно составляют из прописных букв латинского алфавита. Это позволяет отличать макрокоманды от вызова функций.

Макрокоманда внешне синтаксически эквивалентна операции вызова функции, но смысл их различен. Функция в программе имеется в одном экземпляре, но на ее вызов тратится время для подготовки параметров и передачи управления. Каждая макрокоманда замещается соответствующей частью макроопределения, но потерь на передачу управления нет.

Наши рекомендации