Студопедия — Булевы операторы
Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Булевы операторы






Операндами булевых операторов являются булевы (логические) выражения. Три первичных булевых оператора – and, or и not. Все другие булевы операторы выводятся из первичных, т.е. могут быть заменены комбинацией первичных операторов. Результаты булевых операций принято отображать в таблицах истинности (см. табл. 2).

Таблица 2

Таблица истинности булевых операторов and, or и not

А В A and В A or B not A not В
False False False False True True
False True False True True False
True False False True False True
True True True True False False

Как видно из таблицы 2, оператор and выполняет логическую конъюнкцию двух выражений. Это значит, что результат имеет значение True, только если оба операнда равны True. Оператор or выполняет логическую дизъюнкцию двух выражений: результат равен True, если хотя бы один из операндов равен True. Оператор not выполняет логическое отрицание: значение результата операции противоположно значению операнда.

Компилятор Delphi поддерживает два режима вычисления булевых выражений: режим полного и режим неполного вычисления. Эти режимы относятся к операторам and и or. В режиме полного вычисления компилятор продолжает вычисление каждой конъюнкции и дизъюнкции, даже если результат всего выражения уже известен. Пусть, например, результирующее выражение равно A or B, где А и B – некоторые выражения. Допустим, значение выражения А равно True. Тогда выражение В можно не вычислять, так как уже известно, что результирующее выражение истинно. Тем не менее в режиме полного вычисления процессор обрабатывает оба выражения – как А, так и B. В режиме неполного вычисления компилятор конструирует процесс таким образом, что вычисление прекращается, как только становится известным результат всего выражения. Следовательно, в этом примере, если А истинно, то значение B не вычисляется. Применение режима полного вычисления обязательно, когда один из операндов – функция, дополнительно выполняющая какие-либо другие действия. Обычно режим неполного вычисления является предпочтительным, так как в этом случае выполняемый код работает быстрее и занимает в памяти меньше места. Кроме того, в режиме неполного вычисления можно создавать конструкции, которые в режиме полного вычисления вызвали бы во время выполнения ошибку.

По умолчанию компилятор установлен в режим неполного вычисления. Директива этого режима имеет вид {$B-} или {$BOOLEVAL off}. Для локального включения режима полного вычисления можно использовать директиву {$В+} или {$BOOLEVAL ON}. В среде Delphi компилятор можно переключить в режим полного вычисления для всего проекта. Для этого нужно выбрать команду ProjectsàOptions... и в разделе Syntax options (Параметры синтаксиса) вкладки Compiler (Компилятор) установить флажок Complete Boolean eval (Полное булево вычисление).

Следующий пример выполните сначала в режиме неполного вычисления, а затем в режиме полного вычисления. Прокомментируйте, что произошло и в чем отличие первого запуска программы от второго.

program Project2;

{$APPTYPE CONSOLE}

Uses

SysUtils;

Var

byDemon,byNumber: byte;

bValue: boolean;

Begin

byDemon:=0;

byNumber:=1;

bValue:=(byDemon<>0)and((byNumber/byDemon)>1);

writeln(value);

readln;

End.







Дата добавления: 2015-06-29; просмотров: 388. Нарушение авторских прав; Мы поможем в написании вашей работы!



Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...

Важнейшие способы обработки и анализа рядов динамики Не во всех случаях эмпирические данные рядов динамики позволяют определить тенденцию изменения явления во времени...

ТЕОРЕТИЧЕСКАЯ МЕХАНИКА Статика является частью теоретической механики, изучающей условия, при ко­торых тело находится под действием заданной системы сил...

Теория усилителей. Схема Основная масса современных аналоговых и аналого-цифровых электронных устройств выполняется на специализированных микросхемах...

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

Мотивационная сфера личности, ее структура. Потребности и мотивы. Потребности и мотивы, их роль в организации деятельности...

Классификация ИС по признаку структурированности задач Так как основное назначение ИС – автоматизировать информационные процессы для решения определенных задач, то одна из основных классификаций – это классификация ИС по степени структурированности задач...

Сосудистый шов (ручной Карреля, механический шов). Операции при ранениях крупных сосудов 1912 г., Каррель – впервые предложил методику сосудистого шва. Сосудистый шов применяется для восстановления магистрального кровотока при лечении...

Трамадол (Маброн, Плазадол, Трамал, Трамалин) Групповая принадлежность · Наркотический анальгетик со смешанным механизмом действия, агонист опиоидных рецепторов...

Мелоксикам (Мовалис) Групповая принадлежность · Нестероидное противовоспалительное средство, преимущественно селективный обратимый ингибитор циклооксигеназы (ЦОГ-2)...

Studopedia.info - Студопедия - 2014-2024 год . (0.013 сек.) русская версия | украинская версия