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, то программа завершается сообщением об ошибке


 

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

4975. Обработка исключений. Принципы обработки исключений 21.45 KB
  Обработка исключений Исключение ситуация – возникновение непредвиденного или аварийного события, которое может порождаться недостатком ресурсов. Язык Си имеет средства для обработки исключительных ситуаций. Они используются для обработки ошибок...
4976. Экономика и экономическая теория. Учебник 269 KB
  Введение Цель изучения данного курса заключается в усвоении студентами основных положений экономической теории для перспективного ее использования при формировании объективных экономических оценок и формирования рационального экономического мышления...
4977. Бухгалтерское дело. Организация бухгалтерского дела на предприятии 133.57 KB
  Бухгалтерское дело Сущность бухгалтерского дела, его содержание формирование профессии современного бухгалтера и аудитора профессиональные организации бухгалтеров и аудиторов правовой статус бухгалтерской службы, ее место в структуре управления о...
4978. Общие допуски размеров, формы и расположения поверхностей 908 KB
  Общие допуски размеров, формы и расположения поверхностей Ограничение всех геометрических параметров деталей на чертеже должно быть полным и пониматься однозначно: не должно быть разночтений и произвольного истолкования требований при изготовлении и...
4979. Проблематика осмысления прошлого в совместных исследованиях ученых России и Германии 1.02 MB
  Одна из актуальных тем, волнующих российское и германское общество – осмысление недавнего прошлого. Примечательная особенность этого процесса – данную тематику рассматривали на многочисленных конференциях, круглых столах, в совместных изда...
4980. Стилистика. Современный английский язык 1.85 MB
  Основная задача книги - научить сознательно подходить к художественному тексту как целому, рассматривая его в единстве формы и идейного содержания. Все аспекты стилистики, изучаемые современными учеными, нашли свое отражение в данной книге. Функцион...
4981. Оптимальное проектирование процессов транспортировки 118.5 KB
  По картографическому материалу составить: а) граф сложного перекрестка с фиктивными дугами б) модель транспортной сети (ст. метро Курская - ст. метро Чистые пруды) Определить кратчайшее расстояние для модели трансп...
4982. Источниковедение новой и новейшей истории. Курс лекций 218.51 KB
  Источниковедческое исследование является основой любого серьезного исторического исследования С середины XX в наблюдалось возрастание интереса к теоретическому источниковедению, стало больше уделяться внимания проблемам оптимизации научного исследов...
4983. Экономика нефтяной и газовой промышленности. Конспект лекций 706.5 KB
  В данном учебном пособии излагаются методические подходы к выделению отраслевого товарного рынка, его границ, а также методы определения концентрации и рыночной власти продавцов-производителей нефтегазовой промышленности на товарном рынке. ...