28607

Порядковые типы

Доклад

Информатика, кибернетика и программирование

Значения этого типа занимают 4 байта и находятся в диапазоне от 2147483648 до 2147483647. Тип byte беззнаковый целый. Значения этого типа занимают 1 байт и находятся в диапазоне от 0 до 255.

Русский

2013-08-20

17.27 KB

0 чел.

Порядковые типы

Тип integer (целый). Значения этого типа занимают 4 байта и находятся в диапазоне от -2147483648 до 2147483647. Константа MaxInt хранит значение 2147483647.

Тип byte (беззнаковый целый). Значения этого типа занимают 1 байт и находятся в диапазоне от 0 до 255.

Тип word (беззнаковый целый). Значения этого типа занимают 2 байта и находятся в диапазоне от 0 до 65535.

Тип char (символьный). Значения этого типа занимают 1 байт и представляют собой символы в кодировке Windows. Стандартная функция Chr(x) возвращает символ с кодом x. Константы этого типа могут быть записаны в виде #x, где x - целое число от 0 до 255.

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

type 
  
Season = (Winter,Spring,Summer,Autumn);
  DayOfWeek = (Mon,Tue,Wed,Thi,Thr,Sat,Sun);

Значения перечислимого типа занимают 4 байта.

Интервальный тип представляет собой подмножество значений целого, символьного или перечислимого типа и описывается в виде a..b, где a - нижняя, b - верхняя граница интервального типа:

var 
  
a: 0..10;
  c: 'a'..'z';
  d: Mon..Thr; 

Тип, на основе которого строится интервальный тип, называется базовым для этого интервального типа. Значения интервального типа занимают 4 байта.

Строковый тип

Строки в Pascal ABC имеют тип string и состоят из не более чем 255 символов. При описании

var s: string;

под переменную s отводится 256 байт, при этом в нулевом байте хранится длина строки.

Для экономии памяти предусмотрено описание вида

var s1: string[40];

В этом случае под строку отводится 41 байт (нулевой байт - под длину строки). В случае присваивания переменной s1 строки из более чем 40 символов лишние символы отсекаются, и длина строки s1 полагается равной 40.

При выполнении операции конкатенации вида s1+s1 результат считается строкой типа string, т.е.занимает 256 байт. Однако, если при конкатенации результат будет занимать более 255 символов, то программа завершится с ошибкой.

К символам в строке можно обращаться, используя индекс: s[i] обозначает i-тый символ в строке. Обращение к нулевому символу s[0] считается ошибочным. Чтобы изменить длину строки, следует воспользоваться процедурой SetLength. Если индекс i выходит за пределы памяти, отводимой под строку, то выдается сообщение об ошибке. Однако, если индекс i выходит лишь за пределы длины строки, то сообщение об ошибке не выдается.

Массивы

Массив представляет собой набор элементов одного типа, каждый из которых имеет свой номер, называемый индексом (индексов может быть несколько, тогда массив называется многомерным). Тип массива конструируется следующим образом:

array [тип индекса1, ..., тип индексаN] of базовый тип

Тип индекса обязательно представляет собой интервальный тип и обязательно должен задаваться в виде a..b, где a и b - константные выражения целого, символьного или перечислимого типа. Например:

type enum=(w1,w2,w3,w4,w5);
var 
  a1,a2: 
array [1..10] of integer;
  b: 
array ['a'..'z',w2..w4] of string;
  c: 
array [1..10] of array [1..5] of real;

Базовый тип может быть любым (в частности, он может быть типом массива, как для переменной c).

Переменные-массивы одного типа можно присваивать друг другу, при этом будет производиться копирование содержимого одного массива в другой:

a1:=a2;

При передаче по значению параметра типа массив в подпрограмму также производится копирование содержимого массива-фактического параметра в массив-формальный параметр:

procedure p(arr: array [1..10] of integer);
...
p(a1);

Как правило, в этой ситуации копирование содержимого массива не требуется, поэтому массив рекомендуется передавать по ссылке:

procedure r(var arr: array [1..10] of integer);
...
r(a1);

К элементам массива обращаются при помощи переменных с индексами:

a1[3]:=a2[5];
b['f',w3]:='Hello';
c[3][4]:=3.14;

Наиболее часто встречающаяся ошибка при работе с массивами - выход за границы изменения индекса. В Pascal ABCвозникновение этой ошибки приводит к завершению работы программы.

Выражения и операции

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

В Pascal ABC имеются следующие операции: @, not, ^, *, /, divmodandshlshr, +, -, orxor, =, >, <, <>, <= и >=.

Арифметические операции

К арифметическим относятся бинарные операции + - * / для вещественных и целых чисел, бинарные операции div и mod для целых чисел и унарные операции + и - для вещественных и целых чисел. Выражение, имеющее числовой тип, называется арифметическим. Тип арифметического выражения определяется по следующему правилу: если все операнды целые и в выражении отсутствует операция деления /, то выражение имеет тип integer, в противном случае выражение имеет тип real. Например, если b имеет тип byte, c имеет тип 1..9, то b+c и -b имеют тип integer, а 2.0+b и 1/2 - тип real.

Логические операции

К логическим относятся бинарные операции andor и xor, а также унарная операция not, имеющие операнды типа boolean и возвращающие значение типа boolean. Выражение, имеющее тип boolean, называется логическим.

Операции отношения

Операции отношения <, >, <=, >=, =, <> возвращают значение типа boolean и применяются к операндам целого, вещественного, символьного, логического и строкового типов, а также к типизированным указателям. Операции = и <> также применяются к операндам типа pointer, к операндам, являющихся объектами классов и к константе nil. При сравнении символа и строки символ преобразуется в строку длины 1.

Строковые операции

Помимо операций отношения <, >, <=, >=, =, <>, к строковым и символьным операндам применима операция конкатенации (слияния) +. Ее результат имеет строковый тип. Например, 'a'+'b'='ab'. Поскольку строки могут содержать максимум 255 символов, то если сливаются строки суммарной длины больше 255, то программа завершается сообщением об ошибке


 

А также другие работы, которые могут Вас заинтересовать

1236. Лекции по курсу Политология для студентов 1.57 MB
  Политология – наука и учебная дисциплина. Возникновение и основные этапы развития политической науки. Идеи народовластия и государственности в истории политической мысли Украины. Гражданское общество и правовое государство. Происхождение, виды и функции политических элит.
1237. Анализ центра Томско-бурятского сотрудничества Байкал 852.5 KB
  Мосты взаимодействия начало первая. Из Улан-Удэ в Томск начнут летать самолеты четвертая. Молодежный поселок – приживется ли опыт соседей из Бурятии на томской земле? четвертая. По итогам Томского конкурса Человек года-2010 победителем стал выходец из республики Бурятия. Выставка Томского областного художественного музея открылась в Улан-Удэ.
1238. Построение технологического процесса работы станка модели ХШ4-104Ф2Н121 604 KB
  Разработка необходимых данных для проектирования технологического процесса. Отработка (ТКИ) конструкции изделия на технологичность. Выбор и обоснование операций технологического процесса и теоретических схем базирования. Определение припусков на обработку расчетно-аналитическим методом на наружный размер. Расчет и проектирование специального станочного приспособления.
1239. Теория государства и права 708.5 KB
  Предмет теории государства и права, его особенности. Место теории государства и права в системе гуманитарных и юридических наук. Формы и методы осуществления основных функций государства. Формы правления: понятие, признаки, факторы формирования. Республиканская форма правления государства: понятие, признаки, виды.
1240. Особенности использования Microsoft Word 664 KB
  Понятие электронного офиса. Текстовый процессор Microsoft Word. Перемещение по документу. Редактирование текста и расстановка переноса. Создание оглавлений. Работа с редактором формул и редактором картинок.
1241. Теория маркетинга 664 KB
  Сущность маркетинга и эволюция его концепции. Жизненный цикл товара. Товарный знак и знак обслуживания. Регистрация товарного знака. Варианты организации маркетинговой деятельности. Основные понятия, сущность и история развития паблик рилейшнз.
1242. Административное право, ответы к экзамену 1.31 MB
  Понятие и правовое регулирование в административном праве. Понятие и основные черты административно-правовых отношений. Административно-правовые гарантии реализации прав граждан. Обращения граждан. Основные принципы построения и функционирования системы государственной службы: понятие, система и виды.
1243. Информационные системы в экономике 438 KB
  Объективность процесса информатизации, направления ее развития. Основные понятия экономической информатики. Информационный бизнес, рынок, менеджмент. Структура и схема функционально-позадачных информационных систем. Основные направления в развитии инфокоммуникационных технологий. Этапы компьютерного решения экономических задач.
1244. Шпаргалка по логике: Ответы на экзаменационные билеты 531.08 KB
  МЫШЛЕНИЕ КАК ПРЕДМЕТ ЛОГИКИ. ВЗАИМОСВЯЗЬ ЛОГИКИ И ЯЗЫКА. ОСОБЕННОСТИ ЛОГИЧЕСКИХ ЗАКОНОВ И ИХ СВЯЗЬ С ПРИНЦИПАМИ МЫШЛЕНИЯ. ЗАКОН ИСКЛЮЧЕННОГО ТРЕТЬЕГО. ПОНЯТИЕ КАК ФОРМА МЫШЛЕНИЯ. ОБОБЩЕНИЕ И ОГРАНИЧЕНИЕ ПОНЯТИЯ. ОПРЕДЕЛЕНИЕ ПОНЯТИЯ КАК ЛОГИЧЕСКАЯ ОПЕРАЦИЯ.