русс | укр

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

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

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

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


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

ПРОГРАММИРОВАНИЕ ДАННЫХ

Любые данные, то есть константы, переменные, выражения, значения функций, характеризуются своими типами. Тип определяет множество допустимых значений, которые может иметь программируемый объект, множество операций и функций, которые применимы к нему. Тип данных полностью определяет структуру внутреннего хранения информации в памяти компьютера.

Паскаль позволяет программисту определять, конструировать новые пользовательские типы данных. В таблице 20 приведена классификация типов данных, используемых в языке Паскаль. Различают две большие группы данных: простые типы данных и структурированные (сложные). Простые типы являются основой (базой) для определения сложных типов. Типов данных в Паскале очень много, поэтому ограничим наш кругозор ниже приведенной классификацией. Если учесть тот факт, что Паскаль разрешает создавать такие структурированные типы как массив строк, массив записей, массив множеств, массив массивов, или запись, элементами которой являются массивы, записи, множества и т. д., то общее количество определяемых программистом типов будет сколь угодно велико.

Таблица 19

Типы данных языка Паскаль
Скалярные (простые) Указатель Структурированные
Вещественные Порядковые
Целые (перечислимые) Литерный Логический Пользова-тельские
Расширенное Двойное вещественное Вещественное Короткое вещественное Длинное целое Целое Слово Короткое целое Байт Интервальный Перечислимый Файл данных Текстовый файл Множество Строка Запись Массив
extended double real single longint integer word shortint byte char boolean Имя типа задается программистом pointer File text set string record array
                                       

Ранее, основной упор был сделан на классификацию вычислительных процессов, и выработку навыков — определение по внешнему виду задачи требуемых операторов Паскаля, необходимых и достаточных для ее решения.

3.1. Конструирование простых пользовательских типов

Данные простого типа (константы, переменные, выражения) имеют только одно значение, поэтому этот тип часто называют скалярным. К стандартным скалярным типам относятся следующие наиболее известные и часто употребляемые типы: REAL, INTEGER, BOOLEAN, CHAR. Последние три типа содержат ограниченное число значений, поэтому их называют стандартными перечисляемыми типами. Вещественные типы данных, в том числе и REAL, к перечисляемым типам не относятся. Пользователь на базе стандартных перечисляемых типов может создать свои пользовательские типы. Различают два простых пользовательских типа данных:
пользовательские перечисляемые типы и интервальные (иногда говорят ограниченные) типы данных.

Пользовательские перечисляемые типы

Пользователь может конструировать новые скалярные перечисляемые типы, явно описываемые в разделе TYPE:

TYPE <имя типа> = (значение 1, значение 2,..., значение N);

При этом понимают, что «значение i» — это идентификатор элемента с номером i.

Допускается неявное определение перечисляемого типа непосредственно в разделе VAR:

VAR <список переменных> : (значение 1, значение 2,значение N);

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

TYPE G = (С, О, N, F);

VAR Gl, G2: G;

Данные указанных типов можно использовать в операторах FOR и CASE, в функциях SUCC, PRED и ORD. К сожалению, в стандартных процедурах READ, READLN, WRITE, WRITELN эти данные не поддерживаются. Наиболее часто данные пользовательских перечисляемых типов используются при конструировании сложных типов данных (индексы массивов, указателей и т.д.).

Пример 27.

Для заданного года вычислить количество дней.

PROGRAM PR27;

TYPE MONTH - (JAN, FEB, MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT,NOV, DEC);

{Пользовательский перечисляемый тип данных}

VAR

S, YEAR: INTEGER;

MEC: MONTH;

BEGIN

WRITELN ('ВВЕДИТЕ ГОД');

READ (YEAR);

S := 0;

FOR MEC := JAN TO DEC { Просмотр всех месяцев по порядку }

DO CASE MEC OF

APR, JUN, SEP, NOV: S := S+30; { Список месяцев, содержащих 30 дней}

FEB: IF (YEAR MOD 4 = 0) AND (YEAR MOD 100 <> 0) OR (YEAR MOD 400 = 0)

THEN S := S+29 {Апрель, високосный год}

ELSE {IF } S := S+28; { Апрель, не високосный год }

ELSE {CASE}S:=S+31

END; {CASE}

WRITELN ('ЧИСЛО ДНЕЙ:', S)

END.

Перечисляемые типы характеризуются упорядоченностью значений (элементов) этого типа. Существует порядковый номер для каждого идентификатора. Первый в списке идентификатор имеет номер 0, второй 1 и т.д. Исключение составляет тип INTEGER, где номер совпадает с числом. В пользовательском перечисляемом типе номера присваиваются в порядке перечисления идентификаторов при определении типа слева – направо, сверху – вниз. Оператор FOR осуществляет последовательный перебор значений порядковых элементов в соответствии с их упорядоченностью.

На перечисляемых типах данных (стандартных и пользовательских) определены встроенные функции SUCC, PRED, ORD (таблица 11).

Все идентификаторы перечисляемых типов упорядочены по номерам. Примеры:

JAN < FEB < MAR < ... < DEC, (тип пользователя – MONTH);

FALSE < TRUE, (тип – BOOLEAN);

-32768 < -32767 < ... < 32767, (тип – INTEGER);

'a' < 'b' < 'c' < ... < 'z', (тип – CHAR).

Допустимо использовать отношения <, >, =, <>, <=, >= для сравнения переменных, выражений или констант одного перечисляемого типа. Примеры: 'а' < 'b' — имеет значение TRUE;
MAR > DEC — имеет значение FALSE.

Интервальные типы

Для переменных порядкового типа можно создавать интервальный (ограниченный) тип, используя свойство упорядоченности его значений (элементов). Определение интервального типа:

TYPE <Имя типа> = <Левая граница> .. <Правая граница>;

Левая и правая границы представляют собой константы или идентификаторы значений базового типа и задают порядковые номера элементов, ограничивающие диапазон значений переменных создаваемого интервального типа.

Примеры задания интервальных типов:

TYPE

DAY = (SU, МО, TU, WE, ТН, FR, SA);

WORK_DAY = МО .. FR; { Интервальный пользовательский тип}

YEAR = 1900.. 2000; { Интервальные типы}

LAT_ALFABETH = 'А'.. 'Z'; {Стандартные типы}

Над переменными интервального типа допускаются все операции и функции, которые используются на базовом для него порядковом типе.

Просмотров: 462


Вернуться в оглавление



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


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

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

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


 


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

 
 

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