![]() Главная страница Случайная страница КАТЕГОРИИ: АвтомобилиАстрономияБиологияГеографияДом и садДругие языкиДругоеИнформатикаИсторияКультураЛитератураЛогикаМатематикаМедицинаМеталлургияМеханикаОбразованиеОхрана трудаПедагогикаПолитикаПравоПсихологияРелигияРиторикаСоциологияСпортСтроительствоТехнологияТуризмФизикаФилософияФинансыХимияЧерчениеЭкологияЭкономикаЭлектроника |
Синтаксис логических выражений.
Синтаксические правила, рассмотренные в разделе 3.3, не покрывают случай, когда логические выражения могут включать переменные и константы. Эти правила не задают структуру всех возможных допустимых строк, которые могут образовывать логические выражения. Новые правила для логических выражений приведены ниже:
< выражение>:: = < простое выражение> | < простое выражение> < оператор сравнения> < простое выражение>
< простое выражение>:: = < простое выражение> OR < терм> | < терм> < терм>:: = < терм> AND < множитель> | < множитель> < множитель>:: = < переменная> | < константа> | (< выражение>) | NOT < множитель>
Синтаксически некорректно записывать: X < = Y < = Z Для того, чтобы определить, что Y имеет значение, находящееся между значениями X и Z. Вместо этого требуется записать (X < = Y) AND (Y < = Z) чтобы выполнить такую проверку.
Скобки в выражениях – часть синтаксиса Паскаля. Попытка построить синтаксическое дерево для первого выражения терпит неудачу:
Невозможно вывести строку X < = Y из первого < простого выражения> без введения дополнительных символов в строку (например скобок). Для второго выражения может быть построено корректное синтаксическое дерево:
Последовательные лево-ассоциативные операторы с одинаковым приоритетом применяются к их операндам в порядке слева-на-право. Таким образом, в выражении X OR Y OR Z подвыражение X OR Y будет вычислено первым. Синтаксическое дерево для этого выражения будет следующим:
Операнды для каждого OR в строке могут быть найдены поиском строк, выведенных из соотвествующего < простого выражения> и < терма>. Операндами левого OR являются X и Y, тогда как операндами правого OR являются X OR Y (строка выведенная из первого < простоего выражения>) и Z. Таким образом, левый OR применяется к операндам раньше правого. (Конечно, приоритет операторов в выражении может быть изменен с помощью скобок) Правило синтаксиса является леворекурсивным, если определяемая величина (то, что размещается слева от:: =) также появляется на первом месте справа от:: =. Правило для < term> леворекурсивоное: < терм>:: = < терм> AND < множитель> Когда оператор определяется с использованием левой рекурсии, он будет левоассоциативным, как показано на синтаксических деревьях приведенных выше. Относительный приоритет операторов также определен синтаксическими правилами. Синтаксическое дерево для X OR Y AND Z иллюстрирует приоритет операторов:
Несмотря на то, что AND расположен правее OR в строке, он применяется к его операндам, Y и Z до того как OR будет применен к своим операндам, X и Y AND Z. Таким образом, AND имеет более высокий приоритет в логических выражениях, чем OR.
|