25. Анахронизмы Так как язык “C” является развивающимся языком, в старых программах можно встретить некоторые устаревшие конструкции.
Хотя большинство версий компилятора поддерживает такие анахронизмы, они в конце концов исчезнут, оставив за собой только проблемы переносимости.
В ранних версиях “C” для проблем присваивания использовалась форма =ON, а не ON=, приводя к двусмысленностям, типичным примером которых является
X = -1 где X фактически уменьшается, поскольку операции = и - примыкают друг к другу, но что вполне могло рассматриваться и как присваивание -1 к X.
Синтаксис инициализаторов изменился: раньше знак равенства, с которого начинается инициализатор, отсутствовал, так что вместо
INT X = 1;
использовалось INT X 1;
изменение было внесено из-за инициализации INT F (1+2) которая достаточно сильно напоминает определение функции, чтобы смутить компиляторы.
26. Сводка синтаксических правил Эта сводка синтаксиса языка “C” предназначена скорее для облегчения понимания и не является точной формулировкой языка.
26.1. Выражения Основными выражениями являются следующие:
выражение: первичное-выражение выражение & выражение выражение ! Выражение ^ выражение ++ L-значение L-значение L-значение ++ L-значение—
SIZEOF выражение (имя типа) выражение выражение бинарная-операция выражение выражение ? Выражение : выражение L-значение операция-присваивания выражение выражение , выражение первичное выражение: идентификатор константа строка (выражение) первичное-выражение (список выражений необ) первичное-выражение [выражение] L-значение . Идентификатор первичное выражение -> идентификатор L-значение: идентификатор первичное-выражение [выражение] L-значение . Идентификатор первичное-выражение -> идентификатор выражение (L-значение) Операции первичных выражений
() [] . ->
имеют самый высокий приоритет и группируются слева направо. Унарные операции
& - ! ^ ++ -- SIZEOF(Имя типа)
имеют более низкий приоритет, чем операции первичных выражений, но более высокий, чем приоритет любой бинарной операции. Эти операции группируются справа налево. Все бинарные операции и условная операция (прим. Перевод.: условная операция группируется справа налево; это изменение внесено в язык в 1978 г.) группируются слева направо и их приоритет убывает в следующем порядке:
Бинарные операции:
* / %
+ >> <<
< > <= >=
== !=
&
^
!
&&
!!
?:
Все операции присваивания имеют одинаковый приоритет и группируются справа налево.
Операции присваивания:
= += -= *= ?= %= >>= <<= &= ^= !=
Операция запятая имеет самый низкий приоритет и группируется слева направо.
26.2. Описания Описание: спецификаторы-описания список-инициализируемых-описателей необ;
спецификаторы-описания: спецификатор-типа спецификаторы-описания необ спецификатор-класса-памяти спецификаторы-описания необ спецификатор-класса-памяти: AUTO STATIC EXTERN REGISTER TYPEDEF спецификатор-типа: CHAR SHORT INT LONG UNSIGNED FLOAT DOUBLE спецификатор-структуры-или-объединения определяющее-тип-имя список-инициализируемых-описателей: инициализируемый-описатель инициализируемый-описатель, список-инициализируемых-описателей инициализируемый-описатель описатель-инициализатор необ описатель: идентификатор (описатель) описатель описатель () описатель [константное выражение необ] спецификатор-структуры-или-объединения: STRUCT список-описателей-структуры STRUCT идентификатор (список-описаний-структуры) STRUCT идентификатор UNION (список-описаний-структуры) UNION идентификатор (список-описаний-структуры) UNION идентификатор список-описаний-структцры: описание-структуры описание-структуры список-описаний-структуры описание структуры: спецификатор-типа список-описателей-структуры: список-описателей-структуры описатель-структуры описатель-структуры,список-описателей-структуры описатель-структуры: описатель описатель: константное выражение :константное-выражение инициализатор: = выражение = (список-инициализатора) = (список-инициализатора) список инициализатора: выражение список-инициализатора,список-инициализатора (список-инициализатора) имя-типа: спецификатор-типа абстрактный-описатель абстрактный-описатель: пусто (абстрактный-описатель) абстрактный-описатель абстрактный-описатель () абстрактный-описатель [константное-выражение необ] определяющее-тип-имя: идентификатор 26.3. Операторы составной-оператор:
(список-описаний список-операторов
необ необ) список-описаний: описание описание список-описаний список-операторов: оператор оператор список-операторов оператор: составной оператор выражение;
IF (выражение) оператор IF (выражение) оператор ELSE оператор WHILE (выражение) оператор DO оператор WHILE (выражение);
FOR(выражение-1 ;выражение-2 ;выражение-3 )
необ необ необ оператор SWITCH (выражение) оператор CASE константное-выражение : оператор DEFAULT: оператор BREAK;
CONTINUE;
RETURN;
RETURN выражение;
GOTO идентификатор;
идентификатор : оператор
;
26.4. Внешние определения Программа: внешнее-определение внешнее-определение программа внешнее-определение: определение-функции определение-данных определение-функции: спецификатор-типа описатель-функции тело-функции необ описатель-функции: описатель (список-параметров ) необ список-параметров: идетификатор идентификатор , список-параметров тело-функции: список-описаний-типа оператор-функции оператор-функции: (список описаний список-операторов) необ определение данных:
EXTERN спецификатор типа список
необ необ
инициализируемых описателей ;
необ
STATIC спецификатор типа список
необ необ инициализируемых описателей необ;
26.5. Препроцессор #DEFINE идентификатор строка-лексем #DEFINE
#DEFINE идентификатор(идентификатор,...,идентификатор)стр #UNDEF идентификатор #INCLUDE “имя-файла” #INCLUDE <имя-файла> #IF константное-выражение #IFDEF идентификатор #IFNDEF идентификатор #ELSE #ENDIF #LINE константа идентификатор
Последние изменения языка “C” (15 ноября 1978 г.) 27. Присваивание структуры Структуры могут быть присвоены, переданы функциям в качестве аргументов и возвращены функциям. Типы участвующих операндов должны оставаться теми же самыми. Другие правдоподобные операторы, такие как сравнение на равенство, не были реализованы.
В реализации возвращения структур функциями на PDP-11 имеется коварный дефект: если во время возврата происходит прерывание и та же самая функция пеентерабельно вызывается во время этого прерывания, то значение возвращаемое из первого вызова, может быть испорчено. Эта трудность может возникнуть только при наличии истинного прерывания, как из операционной системы, так и из программы пользователя, прерывания, которое существенно для использования сигналов; обычные рекурсивные вызовы совершенно безопасны.
28. Тип перечисления Введен новый тип данных,аналогичный скалярным типам языка паскаль. К спецификатору-типа в его синтаксическом описании в разделе 8.2. Приложения а следует добавить
спецификатор-перечисления
с синтаксисом
пецификатор-перечисления: ENUM список-перечисления ENUM идентификатор список-перечисления
------------- ------------------ENUM идентификатор
cписок-перечисления: перечисляемое список-перечисления, перечисляемое
------------------- ------------перечисляемое: идентификатор идентификатор = константное выражение
------------- --------------------
Роль идентификатора в спецификаторе-перечисления полностью аналогична роли ярлыка структуры в спецификаторе-структуры; идентификатор обозначает определенное перечисление. Например, описание
ENUM COLOR (RED, WHITE, BLACK, BLUE );
. . .
ENUM COLOR *CP, COL;
Объявляет идентификатор COLOR ярлыком перечисления типа, описывающего различные цвета и затем объявляет CP указателем на объект этого типа, а COL - объектом этого типа.
Идентификаторы в списке-перечисления описываются как константы и могут появиться там, где требуются (по контексту) константы. Если не используется вторая форма перечисляемого (с равеством =), то величины констант начинаются с 0 и возрастают на 1 в соответствии с прочтением их описания слева на право. Перечисляемое с присвоением = придает соответствующему идентификатору указанную величину; последующие идентификаторы продолжают прогрессию от приписанной величины.
Все ярлыки перечисления и константы могут быть различными и непохожими на ярлыки и члены структур даже при условии использования одного и того же множества идентификаторов.
Объекты данного типа перечисления рассматриваются как объекты, имеющие тип, отличный от любых типов и контролирующая программа LINT сообщает об ошибках несоответствия типов.
В реализации на PDP-11 со всеми перечисляемыми переменными оперируют так, как если бы они имели тип IN
... основаниям. При этом философская абстракция языка оказывается неразрывно связана с основными темами и движениями философии в целом. Более конкретно, на ранние стадии традиционно рассматриваемого в рамках АФ анализа обыденного языка глубокое влияние оказала философия Дж. Э. Мура, особенно его учение о здравом смысле, согласно которому такие понятия, как «человек», «мир», «я», «внешний мир», « ...
... и других странах СНГ, а также облегчение доступа к русской и мировой культуре и науке. Таким образом, судя по данным наших исследований, востребованность русского языка осталась в республике достаточно высокой. Многие представители современной молдавской молодежи продолжают, как их отцы и деды, тянуться к русской культуре, научным и техническим достижениям России. Русский язык остается языком ...
... рисуночное словесно-слоговое письмо). Памятники среднеэламского периода (14—12 вв. до н.э.) выполнены аккадской клинописью. Памятники новоэламского периода относятся к 8—6 вв. до н.э. Был официальным языком в персидском государстве Ахеменидов в 6—4 вв. предполагается, что он, подвергшись влиянию древнеперсидского, сохранился до раннего средневековья. 7. Бурушаски язык Язык бурушаски ( ...
... /диалект), скифский, согдийский, среднеперсидский, таджикский, таджриши (язык/диалект), талышский, татский, хорезмийский, хотаносакский, шугнано-рушанская группа языков, ягнобский, язгулямский и др. Они относятся к индоиранской ветви индоевропейских языков. Области распространения: Иран, Афганистан, Таджикистан, некоторые районы Ирака, Турции, Пакистана, Индии, Грузии, Российской Федерации. Общее ...
0 комментариев