Category: 

What Is a Branch Table?

Article Details
  • Written By: Jo Dunaway
  • Edited By: C. Wilborn
  • Last Modified Date: 25 August 2016
  • Copyright Protected:
    2003-2016
    Conjecture Corporation
  • Print this Article
Free Widgets for your Site/Blog
The atmosphere of Jupiter's moon Io collapses every time it is eclipsed by the planet.   more...

September 29 ,  2008 :  The Dow Jones Industrial Average experienced its largest one-day drop in history.  more...

A branch table is a method to efficiently transfer program control from one part of a program to another, or to a second program that has been loaded dynamically, by sending a branch of instructions or by implementing a switch statement. This method, sometimes called a jump table, relies on a set of circumstances or conditions to perform a jump to implement a procedure according to a switch statement from a C+ compiler. Some of the main advantages of branch tables are their compact code structure and a reduction in the need to test return codes individually when determining program flow.

In the 1980s, branch tables were used widely in assembly language programming. They are still used in assembly programming for embedded systems and operating systems development. Since the 1990s, compiler programming languages have also made use of branch table functioning.

Branch tables consist of a list of unconditional instructions that, given input, branch off to other destinations. Most computer hardware can execute these instructions efficiently. At times, the offset — essentially, the distance to the destination — can be added to a program counter register that can then point to sets of branch instructions or jump among sets of branch instructions. All that is necessary to implement a branch table is validation of the input code, transforming the data into an offset, and multiplying the data to a given instruction length.

Ad

Embedded programming uses branch tables as they are more memory efficient than using machine code or arrayed pointers. Embedded control systems need that memory savings, and though it may cost a small amount of performance during access to the branch table, any virtual method function call would cost the same amount of performance for stable functioning. The limited CPU access and memory savings in embedded systems need a branch table for static function sets.

Compiler programming languages generate their own branch tables when needed by use of search keys on optimizing compilers. Some programmers choose to manually assist the compiler with contexted branch table generation by giving the compiler two-step conditional parameters from which to search keys. In the earlier years of compiling programs, the branch table implementation used to be the "GoTo" commands in Fortran compiler languages. Branch tables are still used to implement changes in program flow in compiler languages or to be a starting point for repeated instruction sequences.

Ad

You might also Like

Recommended

Discuss this Article

Post your comments

exception 'Exception' with message 'error writing captcha: Duplicate entry '2147483647' for key 'PRIMARY'' in /ssd/www/wisegeek/public_html/_core/classes/public/Captcha.php:44
Stack trace:
#0 /ssd/www/wisegeek/public_html/_core/controls/public/ControlDiscussionPostBox.php(324): Captcha->createCaptcha()
#1 /ssd/www/wisegeek/public_html/framework/classes/Control.php(104): ControlDiscussionPostBox->preRender(false)
#2 /ssd/www/wisegeek/public_html/framework/classes/Control.php(149): Control->render()
#3 /ssd/www/wisegeek/public_html/tpl/default-nocustom-lu/pages/public/article/article.htm(526): Control->__toString()
#4 /ssd/www/wisegeek/public_html/framework/classes/Control.php(300): require('/ssd/www/wisege...')
#5 /ssd/www/wisegeek/public_html/framework/classes/Control.php(309): Control->requireTpl('pages/public/ar...', Object(PageArticleCom), true)
#6 /ssd/www/wisegeek/public_html/framework/classes/Control.php(131): Control->renderTpl('pages/public/ar...', Object(PageArticleCom))
#7 /ssd/www/wisegeek/public_html/framework/classes/FormDataControl.php(87): Control->renderTemplate()
#8 /ssd/www/wisegeek/public_html/framework/classes/Control.php(109): FormDataControl->renderTemplate()
#9 /ssd/www/wisegeek/public_html/framework/classes/ScriptPage.php(50): Control->render(false)
#10 /ssd/www/wisegeek/public_html/framework/classes/Control.php(149): ScriptPage->render()
#11 /ssd/www/wisegeek/public_html/framework/classes/Page.php(97): Control->__toString()
#12 /ssd/www/wisegeek/public_html/_core/classes/public/PublicFrontController.php(443): Page->processRequest()
#13 /ssd/www/wisegeek/public_html/_core/classes/public/PublicFrontController.php(7): PublicFrontController->renderPage()
#14 /ssd/www/wisegeek/public_html/index.php(11): PublicFrontController::run()
#15 {main}