2012-03-16 2 views
4

Как бы вы определили цикл, это бесконечный цикл и выйдет из него.Бесконечная петля: определение и выключение бесконечной петли

Кто-нибудь имеет алгоритм или может помочь мне в этом.

Благодаря

+2

Мое предположение заключается в том, что нет уверенного способа распознать компьютер как бесконечный цикл. Вы должны знать об этом как кодовый инженер. – darijan

+0

Но какой-то интеллектуальный компилятор языка понимает и вытаскивает вас из цикла, если такое происходит. –

+3

Это легко, просто подождите бесконечность и посмотрите, завершена ли программа. – aioobe

ответ

7

Там нет общего алгоритма случая, который может определить, является ли программа в бесконечном цикле или нет для каждого turing complete языка, это в основном Halting Problem.

Идея доказательства его проста:

  1. Предположим, вы имели такой алгоритм A.
  2. Создайте программу B, которая вызывает A на себе [по B].
  3. если A ответы «программа остановится» - сделать бесконечный цикл
  4. еще [A ответы B не остановить] - остановить immidiately

Теперь предположим, вы вызываете A на B - ответ будет определенно неверным, поэтому A не существует.

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

+0

ОК .. что, если вы сказали, чтобы пройти длинный ряд данных, который связан с некоторой точкой той же строки. Является ли это частным случаем проблемы с остановкой или у вас есть какие-либо алгоритмы, связанные с ее решением? –

+3

@PankajGupta: Если я не ошибаюсь - для каждой программы 'A' существует программа' B', которая может определить, остановится ли 'A'. Алгоритма ** общего случая ** нет, который может определить, остановлена ​​ли программа или нет - для ** всех программ **. – amit

4

Как написано другими, оно не может быть определено.

Однако, если вы хотите провести некоторую проверку, вы можете использовать шаблон дизайна WatchDog. Это отдельный поток, который проверяет, активна ли задача. Ваш собственный поток должен регулярно давать сигнал, чтобы сказать, что он жив. Убедитесь, что этот сигнал не установлен внутри вашего (бесконечного) цикла.

Если сигнала не было, программа находится в бесконечном цикле или остановлена, и сторожевой таймер может действовать на нее.