C. Бочков - Язык программирования Си для персонального компьютера
- Название:Язык программирования Си для персонального компьютера
- Автор:
- Жанр:
- Издательство:СП Диалог, Радио и связь
- Год:1990
- ISBN:5-256-00974-5
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
C. Бочков - Язык программирования Си для персонального компьютера краткое содержание
Книга содержит полное описание наиболее распространенных реализаций языка программирования Си на 16-разрядных микроЭВМ, совместимых с IBM PC. Приведено описание стандартных библиотек языка.
Для слушателей учебных курсов в области программирования, разработчиков программного обеспечения, а также студентов соответствующих специальностей вузов. Может быть использовано как техническая документация и справочное пособие для широкого круга программистов, как профессионалов, имеющих большой опыт работы на языке Си, так и начинающих программировать на Си.
Язык программирования Си для персонального компьютера - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
7 6 4 2 1 3 5
1. Идентификатор var объявлен как
2. Указатель на
3. Функцию, возвращающую
4. Указатель на
5. Массив из 10 элементов, которые являются
6. Указателями на
7. Значения типа char.
В приведенных ниже примерах обратите внимание на то, как применение круглых скобок может изменять смысл объявлений.
1. int *var[5]; — массив varуказателей на значения типа int.
2. int (*var)[5]; — указатель varна массив значений типа int.
3. long *var(); — функция var, возвращающая указатель на значение типа long.
4. long (*var)(); — указатель varна функцию, возвращающую значение типа long.
5. struct both {
int a;
char b;
}(*var[5])(); - массив varуказателей на функции, возвращающие структуры типа both.
6. double (*var())[3]; — функция var, возвращающая указатель на массив из трех значений типа double.
7. union sign {
int x;
unsigned y;
} **var[5][5]; — массив var, элементы которого являются массивами указателей на указатели на объединения типа sign.
8. union sign *(*var[5])[5]; — массив var, элементы которого являются указателями на массив указателей на объединения типа sign.
Пояснения к примерам:
В первом примере varобъявляется как массив, поскольку признак типа массив имеет более высокий приоритет, чем признак типа указатель. Элементами массива являются указатели на значения типа int.
Во втором примере скобки меняют смысл объявления из первого примера. Теперь признак типа указатель применяется раньше, чем признак типа массив, и переменная varобъявляется как указатель на массив из пяти значений типа int.
В третьем примере, поскольку признак типа функция имеет более высокий приоритет, чем признак типа указатель, varобъявляется как функция, возвращающая указатель на значение типа long.
Четвертый пример аналогичен второму. С помощью скобок обеспечивается применение признака типа указатель прежде, чем признака типа функция, поэтому переменная varобъявляется как указатель на функцию, возвращающую значение типа long.
Элементы массива не могут быть функциями. Однако в пятом примере показано, как объявить массив указателей на функции. В этом примере переменная varобъявлена как массив из пяти указателей на функции, возвращающие структуры типа both. Заметьте, что круглые скобки, в которые заключено выражение var[5] , обязательны. Без них объявление становится недопустимым, поскольку объявляется массив функций:
struct both *var[5] (struct both, struct both);
В шестом примере показано, как объявить функцию, возвращающую указатель на массив. Здесь объявлена функция var, возвращающая указатель на массив из трех значений типа double. Тип аргумента функции задан составным абстрактным описателем (см. раздел 3.8.3), также специфицирующим указатель на массив из трех значений типа double, В отсутствие круглых скобок, заключающих звездочку, типом аргумента был бы массив из трех указателей на значения типа double.
В седьмом примере показано, что указатель может указывать на другой указатель, а массив может содержать массивы. Здесь varявляется массивом из пяти элементов. Каждый элемент, в свою очередь, также является массивом из пяти элементов, каждый из которых является указателем на указатель на объединение типа sign. Массив массивов является аналогом двумерного массива в других языках программирования.
В восьмом примере показано, как круглые скобки изменили смысл объявления из седьмого примера. В этом примере varявляется массивом из пяти указателей на массив из пяти указателей на объединения типа sign.
Описатели с модификаторами
В разделе 1.4 "Ключевые слова" приведен перечень специальных ключевых слов, реализованных в СП MSC и СП ТС. Использование специальных ключевых слов (называемых в дальнейшем модификаторами) в составе описателей позволяет придавать объявлениям специальный смысл. Информация, которую несут модификаторы, используется компилятором языка Си в процессе генерации кода.
Рассмотрим правила интерпретации объявлений, содержащих модификаторы const, volatile, cdecl, pascal, near, far, huge, interrupt.
Интерпретация описателей с модификаторами
Модификаторы cdecl, pascal, interruptвоздействуют на идентификатор и должны быть записаны непосредственно перед ним.
Модификаторы const, volatile, near, far, hugeвоздействуют либо на идентификатор, либо на звездочку, расположенную непосредственно справа от модификатора. Если справа расположен идентификатор, то модифицируется тип объекта, именуемого этим идентификатором. Если же справа расположена звездочка, то модифицируется тип объекта, на который указывает эта звездочка, т.е. эта звездочка представляет собой указатель на модифицированный тип. Таким образом, конструкция < модификатор >* читается как "указатель на модифицированный тип". Например,
int const *р; - это указатель на const int, а
int * const р; - это constуказатель на int. Модификаторы constи volatileмогут также записываться и перед спецификацией типа.
В СП ТС использование модификаторов near, far, hugeограничено: они могут быть записаны только перед идентификатором функции или перед признаком указателя (звездочкой).
Допускается более одного модификатора для одного объекта (или элемента описателя). В следующем примере тип функции funcмодифицируется одновременно специальными ключевыми словами farи pascal. Порядок специальных ключевых слов не важен, т. е. комбинации far pascalи pascal farимеют один и тот же смысл.
int far * pascal far func();
Тип значения, возвращаемого функцией func, представляет собой указатель на значения типа int. Тип этих значений модифицирован специальным ключевым словом far.
Как обычно, в объявлении могут быть использованы круглые скобки для изменения порядка его интерпретации.
Пример:
char far *(far *getint)(int far *);
7 6 2 1 3 5 4
В примере показано объявление с различными вариантами расположения модификатора far. Учитывая правило, согласно которому модификатор воздействует на элемент описателя, расположенный справа от него, можно проинтерпретировать это объявление следующим образом (шаги интерпретации пронумерованы):
1. Идентификатор getint объявляется как
2. Указатель на far
3. Функцию, требующую
Читать дальшеИнтервал:
Закладка: