русс | укр

Языки программирования

ПаскальСиАссемблерJavaMatlabPhpHtmlJavaScriptCSSC#DelphiТурбо Пролог

Компьютерные сетиСистемное программное обеспечениеИнформационные технологииПрограммирование

Все о программировании


Linux Unix Алгоритмические языки Аналоговые и гибридные вычислительные устройства Архитектура микроконтроллеров Введение в разработку распределенных информационных систем Введение в численные методы Дискретная математика Информационное обслуживание пользователей Информация и моделирование в управлении производством Компьютерная графика Математическое и компьютерное моделирование Моделирование Нейрокомпьютеры Проектирование программ диагностики компьютерных систем и сетей Проектирование системных программ Системы счисления Теория статистики Теория оптимизации Уроки AutoCAD 3D Уроки базы данных Access Уроки Orcad Цифровые автоматы Шпаргалки по компьютеру Шпаргалки по программированию Экспертные системы Элементы теории информации

Описание структур и объединений


Дата добавления: 2015-01-16; просмотров: 578; Нарушение авторских прав


Структура - это объект, состоящий из последовательностиименованных членов. каждый член может быть произвольного ти-па. Объединение - это объект, который в данный момент можетсодержать любой из нескольких членов. Спецификаторы иобъединения имеют одинаковую форму.Спецификатор-структуры-или-объединения структура-или-объединение \( список-описаний-структуры\) идентификатор структуры-или-объединения\(список-описаний-структуры\)идентификатор структуры-или-объединения Структура-или-объединение: STRUCT UNION Список-описаний-структуры является последовательностью опи-саний членов структуры или объединения: Список-описаний-структуры:описание-структурыописание-структуры список-описаний-структуры описание-структуры:спецификатор-типа список-описателей-структуры список-описателей-структуры:описатель-структурыописатель-структуры, список-описателей-структуры В обычном случае описатель структуры является просто описа-телем члена структуры или объединения. Член структуры можеттакже состоять из специфицированного числа битов. Такой членназывается также полем; его длина отделяется от имени полядвоеточием. Описатель-структуры: описатель описатель: константное выражение : константное выражение Внутри структуры описанные в ней объекты имеют адреса, кото-рые увеличиваются в соответствии с чтением их описаний слеванаправо. Каждый член структуры, который не является полем,начинается с адресной границы, соответствующей его типу;следовательно в структуре могут оказаться неименованные ды-ры. Члены, являющиеся полями, помещаются в машинные целые;они не перекрывают границы слова. Поле, которое не умещаетсяв оставшемся в данном слове пространстве, помещается в сле-дующее слово. Поля выделяются справа налево на PDP-11 и сле-ва направо на других машинах. Описатель структуры, который не содержит описателя, атолько двоеточие и ширину, указывает неименованное поле, по-лезное для заполнения свободного пространства с целью соот-ветствия задаваемых извне схемам. Специальный случай неиме-нованного поля с шириной 0 используется для указания о вы-равнивании следующего поля на границу слова. При этом пред-полагается, что "следующее поле" действиетльно является по-лем, а не обычным членом структуры, поскольку в последнемслучае выравнивание осуществляется автоматически. Сам язык не накладывает ограничений на типы объектов,описанных как поля, но от реализаций не требуется обеспечи-вать что-либо отличное от целых полей. Более того, даже полятипа INT могут рассматриваться как неимеющие знака. НаPDP-11 поля не имеют знака и могут принимать только целыезначения. Во всех реализациях отсутствуют массивы полей и кполям не применима операция взятия адреса &, так что не су-ществует и указателей на поля. Объединение можно представить себе как структуру, всечлены которой начинаются со смещения 0 и размер которой дос-таточен, чтобы содержать любой из ее членов. В каждый моментобъединение может содержать не более одного из своих членов. Спецификатор структуры или объединения во второй форме,т.е. Один из STRUCT идентификатор \(список-описаний-структуры\) UNION идентификатор \(список-описаний-структуры\) описывает идентификатор в качестве ярлыка структуры (или яр-лыка объединения) структуры, специфицированной этим списком.Последующее описание может затем использовать третью формуспецификатора, один из STRUCT идентификатор UNION идентификатор Ярлыки структур дают возможность определения структур, кото-рые ссылаются на самих себя; они также позволяют неоднократ-но использовать приведенную только один раз длинную частьописания. Запрещается описывать структуру или объединение,которые содержат образец самого себя, но структура илиобъединение могут содержать указатель на структуру илиобъединение такого же вида, как они сами. Имена членов и ярлыков могут совпадать с именами обычныхпеременных. Однако имена ярлыков и членов должны быть взаим-но различными. Две структуры могут иметь общую начальную последователь-ность членов; это означает, что тот же самый член может поя-виться в двух различных структурах, если он имеет одинаковыйтип в обеих структурах и если все предыдущие члены обеихструктур одинаковы. (Фактически компилятор только проверяет,что имя в двух различных структурах имеет одинаковый тип иодинаковое смещение, но если предшествующие члены отличают-ся, то конструкция оказывается непереносимой). Вот простой пример описания структуры: STRUCT TNODE \( CHAR TWORD[20]; INT COUNT; STRUCT TNODE *LEFT; STRUCT TNODE *RIGHT; \);Такая структура содержит массив из 20 символов, целое и двауказателя на подобные структуры. Как только приведено такоеописание, описание STRUCT TNODE S, *SP; говорит о том, что S является структурой указанного вида, аSP является указателем на структуру указанного вида. При на-личии этих описаний выражение SP->COUNT ссылается к полю COUNT структуры, на которую указывает SP;выражение S.LEFT ссылается на указатель левого поддерева в структуре S, а вы-ражение S.RIGHT->TWORD[0] ссылается на первый символ члена TWORD правого поддерева изS.


<== предыдущая лекция | следующая лекция ==>
Смысл описателей | Инициализация


Карта сайта Карта сайта укр


Уроки php mysql Программирование

Онлайн система счисления Калькулятор онлайн обычный Инженерный калькулятор онлайн Замена русских букв на английские для вебмастеров Замена русских букв на английские

Аппаратное и программное обеспечение Графика и компьютерная сфера Интегрированная геоинформационная система Интернет Компьютер Комплектующие компьютера Лекции Методы и средства измерений неэлектрических величин Обслуживание компьютерных и периферийных устройств Операционные системы Параллельное программирование Проектирование электронных средств Периферийные устройства Полезные ресурсы для программистов Программы для программистов Статьи для программистов Cтруктура и организация данных


 


Не нашли то, что искали? Google вам в помощь!

 
 

© life-prog.ru При использовании материалов прямая ссылка на сайт обязательна.

Генерация страницы за: 0.697 сек.