Jump to content

Многоходовая ветка

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

Альтернативы

[ редактировать ]

Многоходовую ветвь часто можно заменить эффективным поиском по индексированной таблице (с использованием самого значения данных или вычисленной производной значения данных в качестве индекса массива ) . [1]

« ...реализация оператора переключателя приравнивается к реализации многопутевого ветвления. Однако для многих случаев использования оператора переключателя в реальном коде можно вообще избежать ветвления и заменить переключатель одним или несколькими табличными представлениями. -упс. Has30Days пример [представленный ранее] может быть реализован следующим образом: [пример C]"

«Анализ супероптимизатора генерации кода многопутевого ветвления», Роджер Энтони Сэйл

 switch (x) {                     /* x is month no */
   case 4:                        /* April         */                             
   case 6:                        /* June          */
   case 9:                        /* September     */
   case 11:                       /* November      */
   return true;
 }

можно заменить, используя технику «безопасного хеширования», на -

 unsigned int t = x | 2;
 switch (t) {
   case 6:
   case 11:
   return true;
 }

или его можно заменить, используя поиск в таблице сопоставления индексов , на -

 x %= 12;                                           /* to ensure x is in range 0-11*/                                                 
 static const int T[12] ={0,0,0,0,1,0,1,0,0,1,0,1}; /* 0-based table 'if 30 days =1,else 0'  */
 return T[x];                                       /* return with boolean 1 = true, 0=false */

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

Котировки

[ редактировать ]

Многоходовое ветвление — важный метод программирования, который слишком часто заменяется неэффективной последовательностью проверок if. Питер Наур недавно написал мне, что считает использование таблиц для управления ходом выполнения программы основной идеей информатики, которая почти забыта; но он ожидает, что со дня на день оно созреет для повторного открытия. Это ключ к эффективности всех лучших компиляторов, которые я изучал.

Дональд Кнут , Структурное программирование с переходом к операторам.

См. также

[ редактировать ]
  1. ^ «Архивная копия» (PDF) . Архивировано из оригинала (PDF) 27 февраля 2012 г. Проверено 18 ноября 2009 г. {{cite web}}: CS1 maint: архивная копия в заголовке ( ссылка )
[ редактировать ]
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: e16fa265ddd36c3c0258ac99cafc76c9__1706031300
URL1:https://arc.ask3.ru/arc/aa/e1/c9/e16fa265ddd36c3c0258ac99cafc76c9.html
Заголовок, (Title) документа по адресу, URL1:
Multiway branch - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)