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


 

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

25176. Взаємовплив науки і філософії 27.5 KB
  Співвідношення філософії і науки можна показати на прикладі міркувань Патнема. тобто тут висловлюється думка сама про взаємовплив науки і філософії. Філософія створює для науки ціннісно нормативну сферу і в свою чергу беручи за цінності результати отримані наукою.
25177. «ПОВСТАННЯ МАС» як проблема історії ХХ ст.. (Х. Ортега-і-Гассет) 24.5 KB
  Маса за ОртегоюіГасеттом це середня людина без обличчя загальний тип. Маса це кожен хто сприймає себе як усіх інших тобто маса поглинає особистість тому залишається посередність. Маса завжди має жагу до відновлення переходить до насилля це є одичавінням процес розпаду у розумінні ортегаіГассета тому маса переходить до прямих форм дії губить духовні форми. Маса ненавидить тих хто до неї не входить.
25178. Філософія позитивізму та неопозитивізму 29.5 KB
  Філософія позитивізму та неопозитивізму 1. Класичний позитивізм Конт Спенсер Міль 1й позитивізм Наука не пояснює а описує явища. позитивізм переживає кризу викликану прогресом природничонаукового знання. Адже прогрес науки заперечував і знецінював ті синтетичні узагальнення що розглядалися позитивізмом як вічні і незаперечні істини.
25179. «Ідеологія і утопія» (К. Манхейм) 26 KB
  Манхейм Системна спроба дослідження ідеології була зроблена К. Марксу надмірно широке розуміння ідеології. Подруге німецький соціолог виокремив таку важливу характеристику ідеології як систематизованість саме тому ідеологія претендувала на науковість. За цими ознаками виокремлюють два основні різновиди відкриті і тоталітарні ідеології.
25180. Предмет історико-філософської думки 88 KB
  Пригадайте ще років 1520 тому історії філософії відводили місце на крайній периферії у табелі про ранги філософських дисциплін. Головними вважали дослідження з діамату істмату філософських проблем природознавства етики та естетики а історія філософії розташовувалася десь за ними. Приблизно такий самий статус зберігався і в системі викладання: справа зводилася до короткого історикофілософського вступу якому присвячували двітри лекції і на тому історію філософії забували. Є підстави констатувати докорінну зміну статусу історії...
25181. Києво-Могилянська Академія та її роль у формуванні української філософії 25.5 KB
  КиєвоМогилянська Академія та її роль у формуванні української філософії Заснована Петром Могилою у 1632 р. В академії вперше для східних слов'ян почалося систематичне викладання філософії. Викладання філософії передбачало: діалектику логіку фізику математику та метафізику. Про це свідчить хоча б те що кожен професор філософії повинен був виробити собі свій оригінальний курс.
25182. Cимволізм культури. Сутність символу 28 KB
  Зміст поняття символу розкривається через суміжні до нього поняття знаку і образу. Усвідомлення сутності символу неможливе без співвіднесення його з образом. Образ не є уявленням він скоріше предмет уявлення. Будьякий смисл є образом і будьякий образ є хоча б певною мірою символом.
25183. Буття-в-собі і буття-для-себе в параці Ж.-П.Сартра Буття і ніщо 26.5 KB
  Буттявсобі і буттядлясебе в параці Ж.Сартра Буття і ніщо. Буття не створене ніким і нічим воно просто є воно не активне не пасивне не імманенте. Буття є те що воно є це позитивність неповязана з часом.
25184. Філософські школи античності 30.5 KB
  Філософські школи античності Немає філософії взагалі існують її конкретні історичні прояви. Усю 1200 річну історію античної філософії можна розбити на 3 етапи: класика або еллінська філософія еліністична філософія та філософія доби Римської імперії. Рання класика або натурфілософія початковий період філософії. До філософії можна прийти лише знаючи математику.