Google's Go language is a new language. Therefor I was surprised to find that it has a 'goto' statement. I've always been taught that 'goto' statements are a thing of the past and evil for it occludes the actual flow of a program. Function (or methods if you will) are always a better way of controlling flow.
I must be missing something. Why and when is using 'goto' a good idea? Or why did Google include it?
When we actually check Gos source code (the standard library), we can see where
goto
s are actually well applied.For example, in the
math/gamma.go
file, the goto statement is used:The
goto
in this case saves us from introducing another (boolean) variable used just for control-flow, checked for at the end. In this case, thegoto
statement makes the code actually better to read and easier follow (quite in contrary to the argument againstgoto
you mentioned).Also note, that the
goto
statement has a very specific use-case. The language specification on goto states that it may not jump over variables coming into scope (being declared), and it may not jump into other (code-)blocks.Goto is a good idea when none of the built-in control features do quite what you want, and when you can express what you want with a goto. (It's a shame in these cases in some languages when you don't have a goto. You end up abusing some control feature, using boolean flags, or using other solutions worse than goto.)
If some other control feature (used in a reasonably obvious way) can do what you want, you should use it in preference to goto. If not, be bold and use goto!
Finally it's worth noting that Go's goto has some restrictions designed to avoid some obscure bugs. See these restrictions in the spec.
Goto statements has received a lot of discredit since the era of Spaghetti code in the 60s and 70s. Back then there was very poor to none software development methodology. However Goto are not natively evil but can of course be misused and abused by lazy or unskilled programmers. Many problems with abused Gotos can be solved with development processes such as team code reviews.
goto
are jumps in the same technical manner ascontinue
,break
andreturn
. One could argue that these are statements are evil in the same manner but they are not.Why the Go team has included Gotos are probably because of the fact that it is a common flow control primitive. Additionally they hopefully concluded that the scope of Go excludes making an idiot-safe language not possible to abuse.