- Goto
GOTO is a statement found in many computer
programming language s. It is a combination of the English words ' and '. When executed it causes an unconditional transfer of control (a "jump") to another statement. The jumped-to statement is specified using some kind of label, which may be anidentifier or aline number depending on the language. At themachine code level a goto is a form of branch or jump statement.In some languages, goto functionality may be present without explicit use of the keyword goto, such as where a break or continue keyword may be followed by an identifier denoting a label. The
SNOBOL programming language supports a form of statement suffix which causes an unconditional transfer of control after the statement has finished executing.While GOTO statements are found in most
high-level language s, there are a few high-level languages that do not support them. For instance, Java (where goto is areserved word but does not presently serve any function).Usage
The goto statement is often combined with the if statement to cause a conditional transfer of control.
IF "condition" THEN goto "label";
Programming languages impose different restrictions with respect the jump location of a
goto
statement. For example, in theC programming language it is not allowed to jump to a label contained within another function. [ [http://c0x.coding-guidelines.com/6.8.6.1.html C Standard section 6.8.6.1 The goto statement] ] The setjmp/longjmp functions provide support for non-local gotos.Criticism of goto usage
The GOTO statement has been the target of much continued criticism and debate, with the primary negative claim being that use of GOTO results in unreadable and generally unmaintainable "
spaghetti code ". Asstructured programming became more popular in the 1960s and 1970s, manycomputer scientist s came to the conclusion that programs should always use so-called 'structured' flow-control commands such as loops and if-then-else statements in place of GOTO. Even today someprogramming style coding standards forbid the use of GOTO statements using similar rationales. In defense of GOTO statements, others have noted that the restrained use of GOTO does not necessarily lead to poor quality code, and also argue that there are some tasks that cannot be straightforwardly accomplished in many programming languages without the use of one or more GOTO statements, such as implementingfinite state machine s, breaking out of nested loops andexception handling .Probably the most famous criticism of GOTO is a 1968 letter by
Edsger Dijkstra called "Go To StatementConsidered Harmful ". [cite journal
author =Edsger Dijkstra
title = Go To Statement Considered Harmful
year = 1968
month = March
journal = Communications of the ACM
volume = 11
issue = 3
url = http://portal.acm.org/citation.cfm?id=1241518&coll=ACM&dl=ACM&CFID=11218690&CFTOKEN=24551268
pages = 147–148
doi = 10.1145/362929.362947 ] In that letter Dijkstra argued that unrestricted GOTO statements should be abolished from higher-level languages because they complicated the task of analyzing and verifying the correctness of programs (particularly those involving loops). An alternative viewpoint is presented inDonald Knuth 's "Structured Programming with go to Statements" [cite journal
author =Donald Knuth
title = Structured Programming with go to Statements
journal = Computing Surveys
volume = 6
issue = 4
year = 1974
url = http://pplab.snu.ac.kr/courses/adv_pl05/papers/p261-knuth.pdf
pages = 261–301
doi = 10.1145/356635.356640 ] which analyzes many common programming tasks and finds that in some of them GOTO is the optimal language construct to use.This criticism had an effect on the design of some programming languages. Although the designers of the Ada language in the late 1970s were aware of the criticisms of GOTO, the statement was still included in the language, mainly to support automatically generated code where the goto might prove indispensable. [cite book
title = Programming in Ada 2005
author = John Barnes
page = 114–115
date = 2006-06-30
publisher =Addison Wesley
isbn = 0-32-134078-7 |] However, the labels used as the destination of a goto statement take the unusual form of an identifier enclosed in double angle brackets (e.g. <> ) and this syntax is not used anywhere else in the language. This makes it easy to check a program for the existence of goto destinations. The goto statement itself takes the simple form goto Start_Again;.Variations
There are a number of different language constructs which can be described as forms of "goto":
Restricted GOTOs
Many languages, such as C and Java, provide related control flow statements, like break and continue, which are effectively restricted formsof the goto statement. Their effect is an unconditional jump, but they can only be used to jump to a point after the end of a loop block - either to continue a loop at the next iteration (continue), or to end the loop (break).
switch/case structures
The
switch statement in C, C++ and Java effectively performs a multi-way "goto" where the destination is selected by the value of an expression. In some other languages the switch (or case) statement does not behave in precisely this way (it does not have "fall-through" behaviour).Computed GOTO
A computed
GOTO
(originallyFortran terminology) either jumps to one of several labels based on the value of an expression, or jumps to a label that has been stored in a variable. TheON ... GOTO
statement inBASIC supports the first kind of computed GOTO and is useful for case-by-case branching, as in C'sswitch statement . [cite web|url=http://www.qbasicnews.com/qboho/qckadvr@l804a.shtml|title= Microsoft QuickBASIC: ON...GOSUB, ON...GOTO Statements QuickSCREEN.|date= 1988|accessdate= 2008-07-03|publisher=Microsoft ] Some C compilers (e.g., gcc) supportgoto
with a label variable using the label value operator. The "label value operator"&&
returns the address of its operand, which must be a label defined in the current function or a containing function. The value is a constant of typevoid *
and should be used only in a computed goto statement. The feature is an extension to C and C++, implemented to facilitate porting programs developed with GNU C. [ [http://publib.boulder.ibm.com/infocenter/lnxpcomp/v7v91/index.jsp?topic=/com.ibm.vacpp7l.doc/language/ref/clrc08computed_goto.htm Computed goto] , IBM XL C/C++ compiler]Continuations
A
continuation is similar to a computed GOTO in that it transfers control from an arbitrary point in the program to a previously marked point. A continuation can be more flexible than GOTO in some languages because it can leave the current function, something that a GOTO cannot do in most languages. Executing a continuation usually involves some adjustment of the program'scall stack in addition to a jump. The longjmp function of the C programming language is an example of an escape continuation that may be used to escape the current context to a surrounding one. TheCommon Lisp GO operator also has this stack unwinding property, despite the construct being lexically scoped, as the label to be jumped to can be referenced from a closure."COME FROM" GOTO parody
In the
esoteric programming language INTERCAL, which is aparody of languages like BASIC, COME FROM is used instead of GOTO.Perl GOTO
In
Perl , there is a variant of thegoto
statement that is not a traditional GOTO statement at all. It takes a function name and transfers control by effectively substituting one function call for another (atail call ): the new function will not return to the GOTO, but instead to the place from which the original function was called. Early versions ofCOBOL had the ALTER verb to accomplish this.ee also
*
Unstructured programming
* Control flow
*GOSUB References
External links
* [http://www.geek-central.gen.nz/peeves/programming_discipline.html A Structured Discipline of Programming]
Wikimedia Foundation. 2010.