|
||||
|
Назад | Содержание| Вперёд 7. 5. Средства управления К настоящему...Назад | Содержание| Вперёд 7. 5. Средства управления К настоящему моменту мы познакомились сбольшинством дополнительных средств управления,за исключением repeat (повторение). Здесьмы для полноты приводим список всех такихсредств. отсечение, записывается как '!', предотвращает перебор, введено в гл. 5. fail - цель, которая всегда терпит неудачу. true - цель, которая всегда успешна. not( P) - вид отрицания, который всегда ведет себя в точном соответствии со следующим определением: not( P) :- P, !, fail; true. Некоторые проблемы, связанные с отсечением и not детально обсуждались в гл. 5. саll( P) активизирует цель Р. Обращение к саll имеет успех, если имеет успех Р. repeat - цель, которая всегда успешна. Ее особое свойство состоит в том, что она недетерминирована, поэтому всякий раз, как до нее доходит перебор, она порождает новую ветвь вычислений. Цель repeat ведет себя так, как если бы она была определена следующим образом: repeat. repeat :- repeat. Стандартный способ применения repeat показан в процедуре квадраты, которая читает последовательность чисел и выдает их квадраты. Последовательность чисел заканчивается атомом стоп, который служит для процедуры сигналом окончания работы. квадраты :- repeat, read( X), ( X = стоп, !; Y is X*X, write( Y), fail ). Назад | Содержание| Вперёд |
|
||
Главная | В избранное | Наш E-MAIL | Добавить материал | Нашёл ошибку | Наверх |
||||
|