TYPEDEF

Язык С
Строк программы, исключая математическое обеспечение Является учебным введением в центральную часть языка “C” Hачинаем. Единственный способ освоить новый язык Оператор FOR Набор полезных программ Подсчет символов Подсчет слов Функции Аргументы - вызов по значению Область действия: внешние переменные Резюме Константы Описания Преобразование типов До 9 и буквы от а до F Операции и выражения присваивания Старшинство и порядок вычисления Операторы и блоки Переключатель Цикл DO - WHILE Оператор CONTINUE Основные сведения Функции, возвращающие нецелые значения Еще об аргументах функций Правила, определяющие область действия Статические переменные Блочная структура Рекурсия Указатели и адреса Указатели и массивы Адресная арифметика Указатели символов и функции Указатели - не целые До 12, а не от 0 до 11. Так как за экономию памяти у нас пока не награждают, такой способ проще, чем подгонка индек-сов Инициализация массивов указателей Указатели на функции Структуры Структуры и функции Указатели на структуры Мы продемонстрируем, как правильно выполнить эту задачу Поля Определение типа Обращение к стандартной библиотеке Форматный вывод - функция PRINTF Форматный ввод - функция SCANF Форматное преобразование в памяти Обработка ошибок - STDERR и EXIT Обращение к системе Низкоуровневый ввод/вывод - операторы READ и WRITE Произвольный доступ - SEEK и LSEEK Пример - распечатка справочников Пример - распределитель памяти Константы Синтаксическая нотация Преобразования Первичные выражения Унарные операции Аддитивные операции Операция присваивания Спецификаторы типа Описание структур и объединений Инициализация TYPEDEF Оператор SWITCH Внешнее определение функции Область действия внешних идентификаторов Неявные описания Явные преобразования указателей Анахронизмы Операторы
439386
знаков
0
таблиц
0
изображений

16.8. TYPEDEF

Описания, в которых “класс памяти”специфицирован как

TYPEDEF, не вызывают выделения памяти. вместо этого они оп-

ределяют идентификаторы ,которые позднее можно использовать

так, словно они являются ключевыми словами, имеющими основ-

ные или производные типы.

Определяющее-тип-имя

идентификатор

 

В пределах области действия описания со спецификатором

TYPEDEF каждый идентификатор, являющийся частью любого опи-

сателя в этом описании, становится синтаксически эквивалент-

ным ключевому слову, имеющему тот тип , который ассоциирует

с идентификатором в описанном в п. 16.4 Смысле. Например,

после описаний

 

TYPEDEF INT MILES, >KLICKSP;

TYPEDEF STRUCT ( DOUBLE RE, IM; ) COMPLEX;

конструкции

MILES DISTANCE;

EXTERN KLICKSP METRICP;

COMPLEX Z, *ZP;

·    
210 -

становятся законными описаниями; при этом типом DISTANCE яв-

ляется INT, типом METRICP - “указатель на INT”, типом Z -

специфицированная структура и типом ZP - указатель на такую

структуру.

Спецификатор TYPEDEF не вводит каких-либо совершенно но-

вых типов, а только определяет синонимы для типов, которые

можно было бы специфицировать и другим способом. Так в при-

веденном выше примере переменная DISTANCE считается имеющей

точно такой же тип, что и любой другой объект, описанный в

INT.

17. Операторы

За исключением особо оговариваемых случаев, операторы

выполняются последовательно.

17.1. Операторное выражение

Большинство операторов являются операторными выражения-

ми, которые имеют форму

выражение;

обычно операторные выражения являются присваиваниями или об-

ращениями к функциям.

17.2. Составной оператор (или блок)

С тем чтобы допустить возможность использования несколь-

ких операторов там, где ожидается присутствие только одного,

предусматривается составной оператор (который также и экви-

валентно называют “блоком”):

 

составной оператор:

\(список-описаний список-операторов

необ необ\)

список-описаний:

описание

описание список-описаний

список-операторов:

оператор

оператор список-операторов

 

Если какой-либо идентификатор из списка-описаний был описан

ранее, то во время выполнения блока внешнее описание подав-

ляется и снова вступает в силу после выхода из блока.

Любая инициализация автоматических и регистрационных пе-

ременных проводится при каждом входе в блок через его нача-

ло. В настоящее время разрешается (но это плохая практика)

передавать управление внутрь блока; в таком случае эти ини-

циализации не выполняются. Инициализации статических пере-

менных проводятся только один раз, когда начинается выполне-

ние программы.

Находящиеся внутри блока внешние описания не

резервируют памяти, так что их инициализация не

разрешается.

·      
211 -

17.3. Условные операторы Имеются две формы условных операторов:

 

IF (выражение) оператор

IF (выражение) оператор ELSE оператор

 

В обоих случаях вычасляется выражение и, если оно отлично от

нуля, то выполняется первый подоператор. Во втором случае,

если выражение равно нулю, выпалняется второй подоператор.

Как обычно, двусмысленность “ELSE” разрешается связываением

ELSE с последним встречающимся IF, у которого нет ELSE.

17.4. Оператор WHILE

Оператор WHILE имеет форму

WHILE (выражение) оператор

Подоператор выполняется повторно до тех пор, пока значение

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

перед каждым выполнением оператора.

17.5. Оператор DO

Оператор DO имеет форму

DO оператор WHILE (выражения)

Оператор выполняется повторно до тех пор, пока значение выражения не станет равным нулю. Проверка производится после каждого выполнения оператора.

17.6. Оператор FOR

Оператор FOR имеет форму

(выражение-1 ; выражение-2 ; выражение-3 )оператор

необ необ необ

Оператор FOR эквивалентен следующему

выражение-1;

WHILE (выражение-2) \(

оператор

выражение-3

\)

 

Таким образом, первое выражение определяет инициализацию

цикла; второе специфиуирует проверку, выполняемую перед каж-

дой итерацией, так что выход из цикла происходит тогда, ког-

да значение выражения становится нулем; третье выражение

часто задает приращение параметра, которое проводится после

каждой итерации.

Любое выражение или даже все они могут быть опущены. Ес-

ли отсутствует второе выражение, то предложение с WHILE счи-

тается эквивалентным WHILE(1); другие отсутствующие выраже-

ния просто опускаются из приведенного выше расширения.


·     212 -


Информация о работе «Язык С»
Раздел: Информатика, программирование
Количество знаков с пробелами: 439386
Количество таблиц: 0
Количество изображений: 0

Похожие работы

Скачать
48443
0
0

... основаниям. При этом философская абстракция языка оказывается неразрывно связана с основными темами и движениями философии в целом. Более конкретно, на ранние стадии традиционно рассматриваемого в рамках АФ анализа обыденного языка глубокое влияние оказала философия Дж. Э. Мура, особенно его учение о здравом смысле, согласно которому такие понятия, как «человек», «мир», «я», «внешний мир», « ...

Скачать
43709
0
0

... и других странах СНГ, а также облегчение доступа к русской и мировой культуре и науке. Таким образом, судя по данным наших исследований, востребованность русского языка осталась в республике достаточно высокой. Многие представители современной молдавской молодежи продолжают, как их отцы и деды, тянуться к русской культуре, научным и техническим достижениям России. Русский язык остается языком ...

Скачать
39778
0
1

... рисуночное словесно-слоговое письмо). Памятники среднеэламского периода (14—12 вв. до н.э.) выполнены аккадской клинописью. Памятники новоэламского периода относятся к 8—6 вв. до н.э. Был официальным языком в персидском государстве Ахеменидов в 6—4 вв. предполагается, что он, подвергшись влиянию древнеперсидского, сохранился до раннего средневековья. 7. Бурушаски язык Язык бурушаски ( ...

Скачать
64931
0
0

... /диалект), скифский, согдийский, среднеперсидский, таджикский, таджриши (язык/диалект), талышский, татский, хорезмийский, хотаносакский, шугнано-рушанская группа языков, ягнобский, язгулямский и др. Они относятся к индоиранской ветви индоевропейских языков. Области распространения: Иран, Афганистан, Таджикистан, некоторые районы Ирака, Турции, Пакистана, Индии, Грузии, Российской Федерации. Общее ...

0 комментариев


Наверх