- •Конспект лекций Часть 2 Оглавление
- •Часть 2 1
- •8. Указатели
- •8.1. Указатели Понятие указателя
- •Работа с указателями
- •Арифметика указателей
- •Ошибки при работе с указателями
- •If (p1) // Если указатель не равен 0, то все в порядке
- •8.2. Указатели и массивы
- •9. Функции и структура программы
- •9.1. Создание и использование функций Процедурный подход к разработке программ
- •Int Максимум_строки (int Строка)
- •Int Минимум_строки (int Строка)
- •Int Максимум_столбца (int Столбец)
- •Int Минимум_столбца (int Столбец)
- •Определение функций в программе
- •Завершение работы функции (инструкция return)
- •If ( Ошибка )
- •Список параметров функций
- •Обращение к функциям в программе
- •Передача данных по значению
- •Передача данных с помощью указателей
- •Передача данных по ссылке
- •Перегружаемые функции
- •Параметры по умолчанию
- •Функции с переменным числом параметров
- •Рекурсивное использование функций
- •Передача функций в качестве параметров
- •Встраиваемые функции (inline - функции)
- •Прототипы функций
- •9.2. Структура программы. Глобальные и локальные данные (области видимости и время жизни) Структура программы
- •Глобальные и локальные данные
- •Классы памяти
- •Многофайловые проекты
- •10. Структуры, объединения, перечисления
- •10.1. Структуры Определение структур
- •Доступ к полям структур
- •Указатели на структуры
- •Структурные параметры функций
- •Битовые поля структур
- •10.2. Объединения Обычные объединения
- •Анонимные объединения
- •10.3. Перечисления
- •Void WriteColor (тип_Спектр c )
- •11. Организация работы с файлами
- •11.1. Потоки для работы с файлами Общие сведения
- •Пример работы с файлом
- •11.2. Работа с файлами Создание потока, открытие и закрытие файла
- •Запись и чтение данных в текстовых файлах
- •Запись и чтение данных в двоичном режиме
- •If ( !File ) // Проверили удалось ли открыть файл
- •Как обнаружить конец файла?
- •Прямой доступ при работе с файлами
- •If ( !File ) // Проверили удалось ли открыть файл
- •Статус потоков ввода-вывода
- •Некоторые другие функции управления потоками ввода-вывода
- •Примеры по работе с файлами
- •12. Работа с динамической памятью Распределение памяти при работе программы
- •Динамическое выделение и освобождение памяти в стиле c
- •Возможные ошибки при работе с динамической памятью
- •Динамические массивы
- •Одномерные однонаправленные списки
- •Одномерные двунаправленные списки
- •Многомерные списки
Многофайловые проекты
Напишу позже!!!
10. Структуры, объединения, перечисления
Все данные, с которыми работает программа можно разделить на две группы:
простые;
структурированные.
Из рассмотренных ранее типов данных к структурированным типам относятся массивы, остальные типы данных – простые – не имеющие внутренней структуры.
Структуры и объединения относятся к структурированным (конгломератным) типам данных, определяемых программистом.
10.1. Структуры Определение структур
Структуры представляют собой группы связанных между собой, как правило, разнотипных переменных, объединенных в единый объект.
Для работы с некоторой структурой в программе необходимо:
описать тип данных этой структуры;
определить переменные этого типа для хранения соответствующих данных в памяти.
Рассмотрим пример: сведения о студенте содержат следующие данные:
фамилия - Fam;
имя - Name;
год рождения - Year;
пол - Sex;
средний балл - Grade.
Представим все эти данные в виде единой структуры. Введем новый тип данных (назовем его t_Student) для описания этой структуры:
struct t_Student {
char Fam [20],
Name [16];
short Year;
bool Sex;
float Grade;
};
Описание структуры начинается ключевым словом struct. Каждая входящая в структуру переменная называется членом (полем, элементом) структуры и описывается типом данных и именем. Поля структуры могут быть любого типа данных. Их количество не лимитировано.
Вся эта конструкция является инструкцией языка программирования, поэтому после нее всегда должен ставиться символ ;.
При описании структуры память для размещения данных не выделяется. Работать с описанной структурой можно только после того, как будет определена переменная (переменные) этого типа данных, только при этом компилятор выделит необходимую память:
t_Student St1, St2; // Определены две переменные типаt_Student
Определение переменных можно осуществить одновременно с описанием типа данных структуры:
struct t_Student {
char Fam [20],
Name [16];
short Year;
bool Sex;
float Grade;
} St1, St2;
Все поля структурных переменных располагаются в непрерывной области памяти одно за другим. Общий объем памяти, занимаемый структурой, равен сумме размеров всех полей структуры. Для определения размера структуры следует использовать инструкцию sizeof ():sizeof (t_Student)илиsizeof (St2).
Доступ к полям структур
Для того чтобы записать данные в структурную переменную, необходимо каждому полю структуры присвоить определенное значение. Для этого необходимо научиться получать доступ к полям. Для этого используется оператор “точка”. Например:
strcpy ( St1.Fam, “Иванов” );
strcpy ( St1.Name, “Владимир” );
St1.Year = 1995;
St1.Sex = true; // Надо договориться какое значение соответствует значению пола
St1.Grade = 4.67;
При доступе к определенному полю его следует рассматривать как обычную переменную, тип данных которой соответствует типу этого поля. Поля структур могут участвовать в качестве операндов любых выражений, допускающих использование операндов соответствующего типа данных.
Копирование данных из одной структурной переменной в другую осуществляется простой операцией присваивания не зависимо от количества полей и размера структуры (это можно делать только в том случае, когда обе переменные одного и того же типа):
St2 = St1;
Теперь переменная St2 содержит те же данные, что и переменнаяSt1.
В программировании очень часто используются такие конструкции, как массивы структур. Например, сведения о студентах некоторой учебной группы можно хранить в массиве студентов:
t_Student Gruppa [25];
Здесь мы определили 25-ти элементный массив, каждый элемент которого предназначен для хранения данных одного студента. Получение доступа к данным некоторого студента из группы осуществляется обычной индексацией переменной массива:
St1 = Gruppa [10]; // ПеременнаяSt1содержит сведения об 11-ом студенте
Доступ к некоторому полю студента внутри массива делается так:
double grade = Gruppa[10].Grade; // Переменная grade содержит среднюю оценку 11-ого студента
Если некоторое поле структуры представляет собой массив (например, поле Fam– это массив символов), доступ к отдельному элементу этого массива можно выполнить так:
St1.Fam[5] = ‘ш’;
Или так:
Gruppa[10].Fam[5] = ‘ш’;
Поскольку поля структуры могут быть любого типа данных, то они могут в свою очередь быть другой структурой или массивом других структур. Определим группу, как структуру, содержащую три поля – номер группы, количество студентов в группе и массив студентов этой группы.
Определяем новый тип данных и переменные для двух групп:
struct t_Gruppa {
short NumGr; // Номер группы
short Count; // Количество студентов в группе
t_Student Students[25]; // Массив студентов группы
} Gr1372, St1373;
Получим данные о некотором студенте из группы Gr1372:
St1 = Gr1372.Students[10]; // ПеременнаяSt1содержит сведения об 11-ом студенте
А вот его средний балл:
grade = Gr1372.Students[10].Grade;
В структуре в качестве поля нельзя использовать элемент, тип которого совпадает с типом самой структуры (рекурсивное использование структур запрещено).