Vícecestná větev - Multiway branch

Vícecestná větev je změna programu regulační tok na základě hodnoty odpovídající vybraným kritériím. Je to forma podmíněné prohlášení. Vícecestná větev je často nejvíce účinný způsob předání řízení jedné ze sady popisky programů, zvláště pokud index byl vytvořen předem z hrubá data.

Příklady

Alternativy

Vícecestná větev může být často nahrazena efektivní indexovanou vyhledávání v tabulce (pomocí samotné datové hodnoty nebo vypočítané derivace datové hodnoty jako indexu pole )[1]

"... implementace příkazu switch byla srovnávána s implementací vícecestné větve. Pro mnoho použití příkazu switch v reálném kódu je však možné úplně se větvení vyhnout a nahradit switch jedním nebo více vyhledáními v tabulce. Například Má 30 dní příklad [představený dříve] lze implementovat jako následující: [příklad C] "

„Superoptimizační analýza generování vícecestných kódů poboček“ Roger Anthony Sayle

 přepínač (X) {                     / * x je měsíc ne * /   případ 4:                        /* Duben         */                                případ 6:                        /* Červen          */   případ 9:                        / * Září * /   případ 11:                       /* Listopad      */   vrátit se skutečný; }

lze nahradit technikou „bezpečného hašování“ pomocí -

 nepodepsaný int t = X | 2; přepínač (t) {   případ 6:   případ 11:   vrátit se skutečný; }

nebo jej lze vyměnit pomocí mapování indexů vyhledávání v tabulce s -

 X %= 12;                                           / * zajistit, aby x bylo v rozsahu 0-11 * /                                                  statický konst int T[12] ={0,0,0,0,1,0,1,0,0,1,0,1}; / * 0-based table 'if 30 days = 1, else 0' * / vrátit se T[X];                                       / * návrat s logickou hodnotou 1 = true, 0 = false * /

(s ohledem na jednoduchost druhého případu by bylo vhodnější implementovat jej in-line, protože režie použití volání funkce může být větší než samotné indexované vyhledávání.)

Citace

Vícecestné větvení je důležitá programovací technika, která je až příliš často nahrazena neúčinnou posloupností if testů. Peter Naur nedávno mi napsal, že považuje použití tabulek k řízení toku programu za základní myšlenku informatiky, která byla téměř zapomenuta; ale očekává, že dnes bude zralý pro znovuobjevení. Je to klíč k efektivitě u všech nejlepších překladačů, které jsem studoval.

— Donald Knuth, Strukturované programování s přechodem na příkazy

Viz také

Reference

  1. ^ „Archivovaná kopie“ (PDF). Archivovány od originál (PDF) dne 2012-02-27. Citováno 2009-11-18.CS1 maint: archivovaná kopie jako titul (odkaz)

externí odkazy