Как остановить рекурсивный вызов: семь подходов

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

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

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

Для управления контекстом выполнения можно использовать механизмы продолжений, с помощью которых рекурсивная функция может передать управление в точку вызова. Аналогом в императивных языках является оператор goto, но с ним есть ограничения. Еще один способ — это изменение лексического контекста, при котором рекурсивная функция меняет свое собственное определение на другое, завершающееся. Такой подход доступен в динамических языках.


Новое на сайте

19905Зачем древние египтяне строили круглые храмы? 19904Планета, на которой вы живёте, но почти не знаете 19903Может ли анализ крови остановить рак печени ещё до его начала? 19902Кто такие GopherWhisper и зачем им монгольские чиновники? 19901«Вояджер-1» готовится к манёвру «большой взрыв»: NASA отключает приборы ради выживания 19900Почему вокруг Чатемских островов появилось светящееся кольцо из планктона? 19899Как взлом Vercel начался с Roblox-скрипта на чужом компьютере 19898Кто лежит в шотландских гробницах каменного века? 19897Почему две англосаксонские сестра и брат были похоронены в объятиях 1400 лет назад? 19896Гормон GDF15: найдена причина мучительного токсикоза у беременных 19895Почему хакеры Harvester прячут вредоносный код в папке «Zomato Pizza»? 19894Робот-гуманоид Panther от UniX AI претендует на место в каждом доме 19893Artemis застряла на земле: NASA не может лететь на луну без новых скафандров 19892Почему 20 000 промышленных устройств по всему миру оказались под угрозой взлома? 19891Зачем египетская мумия «проглотила» «Илиаду»?
Ссылка