Go (Programming Language) - Wikipedia
Go (Programming Language) - Wikipedia
org/wiki/Go_(programming_language)
Go (programming language)
(Redirected from Golang)
1 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
slanting right with trailing streamlines. (e Gopher mascot C, Oberon-2, Limbo, Active
remained the same.[35]) Oberon, communicating
sequential processes, Pascal,
Oberon, Smalltalk, Newsqueak,
Generics Modula-2, Alef, APL, BCPL,
e lack of support for generic programming in initial versions Modula, occam
of Go drew considerable criticism.[36] e designers expressed Influenced
an openness to generic programming and noted that built-in Crystal, V (Vlang)
functions were in fact type-generic, but are treated as special
cases; Pike called this a weakness that might be changed at some
point.[37] e Google team built at least one compiler for an
experimental Go dialect with generics, but did not release it.[38]
In June 2020, a new dra design document[42] was published that would add the necessary syntax to Go
for declaring generic functions and types. A code translation tool, go2go, was provided to allow users
to try the new syntax, along with a generics-enabled version of the online Go Playground.[43]
Versioning
Go 1 guarantees compatibility[45] for the language specification and major parts of the standard library.
All versions up through the current Go 1.22 release[46] have maintained this promise.
Go does not follow SemVer; rather, each major Go release is supported until there are two newer minor
releases. Unlike most soware, Go calls the second number in a version the major, i.e., in 1.x x is the
major version. [47] is is because Go plans to never reach 2.0, given that compatibility is one of
language's major selling points.[48]
Design
2 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
Go is influenced by C (especially the Plan 9 dialect[49]), but with an emphasis on greater simplicity and
safety. It consists of:
Syntax
Go's syntax includes changes from C aimed at keeping code concise and readable. A combined
declaration/initialization operator was introduced that allows the programmer to write i := 3 or s
:= "Hello, world!", without specifying the types of variables used. is contrasts with C's int
i = 3; and const char *s = "Hello, world!";.
Semicolons still terminate statements;[b] but are implicit when the end of a line occurs.[c]
Methods may return multiple values, and returning a result, err pair is the conventional way a
method indicates an error to its caller in Go.[d] Go adds literal syntaxes for initializing struct
parameters by name and for initializing maps and slices. As an alternative to C's three-statement for
loop, Go's range expressions allow concise iteration over arrays, slices, strings, maps, and
channels.[57]
Types
Go has a number of built-in types, including numeric ones (byte, int64, float32, etc.), booleans,
and byte strings (string). Strings are immutable; built-in operators and keywords (rather than
functions) provide concatenation, comparison, and UTF-8 encoding/decoding.[58] Record types can be
defined with the struct keyword.[59]
For each type T and each non-negative integer constant n, there is an array type denoted [n]T; arrays
of differing lengths are thus of different types. Dynamic arrays are available as "slices", denoted []T for
some type T. ese have a length and a capacity specifying when new memory needs to be allocated to
expand the array. Several slices may share their underlying memory.[37][60][61]
3 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
Pointers are available for all types, and the pointer-to-T type is denoted *T. Address-taking and
indirection use the & and * operators, as in C, or happen implicitly through the method call or aribute
access syntax.[62][63] ere is no pointer arithmetic,[e] except via the special unsafe.Pointer type
in the standard library.[64]
For a pair of types K, V, the type map[K]V is the type mapping type-K keys to type-V values, though
Go Programming Language specification does not give any performance guarantees or implementation
requirements for map types. Hash tables are built into the language, with special syntax and built-in
functions. chan T is a channel that allows sending values of type T between concurrent Go
processes.[65]
Aside from its support for interfaces, Go's type system is nominal: the type keyword can be used to
define a new named type, which is distinct from other named types that have the same layout (in the
case of a struct, the same members in the same order). Some conversions between types (e.g.,
between the various integer types) are pre-defined and adding a new type may define additional
conversions, but conversions between named types must always be invoked explicitly.[66] For example,
the type keyword can be used to define a type for IPv4 addresses, based on 32-bit unsigned integers as
follows:
With this type definition, ipv4addr(x) interprets the uint32 value x as an IP address. Simply
assigning x to a variable of type ipv4addr is a type error.[67]
Constant expressions may be either typed or "untyped"; they are given a type when assigned to a typed
variable if the value they represent passes a compile-time check.[68]
Function types are indicated by the func keyword; they take zero or more parameters and return zero
or more values, all of which are typed. e parameter and return values determine a function type;
thus, func(string, int32) (int, error) is the type of functions that take a string and a
32-bit signed integer, and return a signed integer (of default width) and a value of the built-in interface
type error.[69]
Any named type has a method set associated with it. e IP address example above can be extended
with a method for checking whether its value is a known standard:
Due to nominal typing, this method definition adds a method to ipv4addr, but not on uint32.
While methods have special definition and call syntax, there is no distinct method type.[70]
Interface system
Go provides two features that replace class inheritance.
4 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
e second are its interfaces, which provides runtime polymorphism.[72]:266 Interfaces are a class of
types and provide a limited form of structural typing in the otherwise nominal type system of Go. An
object which is of an interface type is also of another type, much like C++ objects being simultaneously
of a base and derived class. Go interfaces were designed aer protocols from the Smalltalk
programming language.[73] Multiple sources use the term duck typing when describing Go interfaces.
[74][75] Although the term duck typing is not precisely defined and therefore not wrong, it usually
implies that type conformance is not statically checked. Because conformance to a Go interface is
checked statically by the Go compiler (except when performing a type assertion), the Go authors prefer
the term structural typing.[76]
e definition of an interface type lists required methods by name and type. Any object of type T for
which functions exist matching all the required methods of interface type I is an object of type I as well.
e definition of type T need not (and cannot) identify type I. For example, if Shape, Square and
Circle are defined as
import "math"
then both a Square and a Circle are implicitly a Shape and can be assigned to a Shape-typed
variable.[72]:263–268 In formal language, Go's interface system provides structural rather than nominal
typing. Interfaces can embed other interfaces with the effect of creating a combined interface that is
satisfied by exactly the types that implement the embedded interface and any methods that the newly
defined interface adds.[72]:270
e Go standard library uses interfaces to provide genericity in several places, including the
input/output system that is based on the concepts of Reader and Writer.[72]:282–283
Besides calling methods via interfaces, Go allows converting interface values to other types with a run-
time type check. e language constructs to do so are the type assertion,[77] which checks against a
single potential type:
5 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
e empty interface interface{} is an important base case because it can refer to an item of any
concrete type. It is similar to the Object class in Java or C# and is satisfied by any type, including
built-in types like int.[72]:284 Code using the empty interface cannot simply call methods (or built-in
operators) on the referred-to object, but it can store the interface{} value, try to convert it to a
more useful type via a type assertion or type switch, or inspect it with Go's reflect package.[79]
Because interface{} can refer to any value, it is a limited way to escape the restrictions of static
typing, like void* in C but with additional run-time type checks.
e interface{} type can be used to model structured data of any arbitrary schema in Go, such as
JSON or YAML data, by representing it as a map[string]interface{} (map of string to empty
interface). is recursively describes data in the form of a dictionary with string keys and values of any
type.[80]
Interface values are implemented using pointer to data and a second pointer to run-time type
information.[81] Like some other types implemented using pointers in Go, interface values are nil if
uninitialized.[82]
Functions and types now have the ability to be generic using type parameters. ese type parameters
are specified within square brackets, right aer the function or type name.[84] e compiler transforms
the generic function or type into non-generic by substituting type arguments for the type parameters
provided, either explicitly by the user or type inference by the compiler.[85] is transformation process
is referred to as type instantiation.[86]
Interfaces now can define a set of types (known as type set) using | (Union) operator, as well as a set of
methods. ese changes were made to support type constraints in generics code. For a generic function
or type, a constraint can be thought of as the type of the type argument: a meta-type. is new ~T
syntax will be the first use of ~ as a token in Go. ~T means the set of all types whose underlying type is
T.[87]
6 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
return sum
}
func main() {
add := Add[int] // Type instantiation
println(add(1, 2, 3, 4, 5)) // 15
Enumerated types
Go uses the iota keyword to create enumerated constants.[88]
const (
_ = iota // ignore first value by assigning to blank identifier
KB ByteSize = 1 << (10 * iota)
MB
GB
)
Package system
In Go's package system, each package has a path (e.g., "compress/bzip2" or "golang.org/x
/net/html") and a name (e.g., bzip2 or html). References to other packages' definitions must
always be prefixed with the other package's name, and only the capitalized names from other packages
are accessible: io.Reader is public but bzip2.reader is not.[89] e go get command can
retrieve packages stored in a remote repository[90] and developers are encouraged to develop packages
inside a base path corresponding to a source repository (such as example.com/user_name
/package_name) to reduce the likelihood of name collision with future additions to the standard library
or other external libraries.[91]
e primary concurrency construct is the goroutine, a type of green thread.[93]:280–281 A function call
prefixed with the go keyword starts a function in a new goroutine. e language specification does not
specify how goroutines should be implemented, but current implementations multiplex a Go process's
goroutines onto a smaller set of operating-system threads, similar to the scheduling performed in
Erlang.[94]:10
While a standard library package featuring most of the classical concurrency control structures (mutex
locks, etc.) is available,[94]:151–152 idiomatic concurrent programs instead prefer channels, which send
messages between goroutines.[95] Optional buffers store messages in FIFO order[96]:43 and allow
sending goroutines to proceed before their messages are received.[93]:233
Channels are typed, so that a channel of type chan T can only be used to transfer messages of type T.
7 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
Special syntax is used to operate on them; <-ch is an expression that causes the executing goroutine to
block until a value comes in over the channel ch, while ch <- x sends the value x (possibly blocking
until another goroutine receives the value). e built-in switch-like select statement can be used
to implement non-blocking communication on multiple channels; see below for an example. Go has a
memory model describing how goroutines must use channels or other operations to safely share
data.[97]
e existence of channels does not by itself set Go apart from actor model-style concurrent languages
like Erlang, where messages are addressed directly to actors (corresponding to goroutines). In the actor
model, channels are themselves actors, therefore addressing a channel just means to address an actor.
e actor style can be simulated in Go by maintaining a one-to-one correspondence between
goroutines and channels, but the language allows multiple goroutines to share a channel or a single
goroutine to send and receive on multiple channels.[94]:147
From these tools one can build concurrent constructs like worker pools, pipelines (in which, say, a file
is decompressed and parsed as it downloads), background calls with timeout, "fan-out" parallel calls to
a set of services, and others.[98] Channels have also found uses further from the usual notion of
interprocess communication, like serving as a concurrency-safe list of recycled buffers,[99]
implementing coroutines (which helped inspire the name goroutine),[100] and implementing
iterators.[101]
Concurrency-related structural conventions of Go (channels and alternative channel inputs) are derived
from Tony Hoare's communicating sequential processes model. Unlike previous concurrent
programming languages such as Occam or Limbo (a language on which Go co-designer Rob Pike
worked),[102] Go does not provide any built-in notion of safe or verifiable concurrency.[103] While the
communicating-processes model is favored in Go, it is not the only one: all goroutines in a program
share a single address space. is means that mutable objects and pointers can be shared between
goroutines; see § Lack of data race safety, below.
8 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
Binaries
e linker in the gc toolchain creates statically linked binaries by default; therefore all Go binaries
include the Go runtime.[111][112]
Omissions
Go deliberately omits certain features common in other languages, including
(implementation) inheritance, assertions,[] pointer arithmetic,[e] implicit type conversions, untagged
unions,[g] and tagged unions.[h] e designers added only those facilities that all three agreed on.[115]
Of the omied language features, the designers explicitly argue against assertions and pointer
arithmetic, while defending the choice to omit type inheritance as giving a more useful language,
encouraging instead the use of interfaces to achieve dynamic dispatch[i] and composition to reuse code.
Composition and delegation are in fact largely automated by struct embedding; according to
researchers Schmager et al., this feature "has many of the drawbacks of inheritance: it affects the public
interface of objects, it is not fine-grained (i.e, no method-level control over embedding), methods of
embedded objects cannot be hidden, and it is static", making it "not obvious" whether programmers will
overuse it to the extent that programmers in other languages are reputed to overuse inheritance.[71]
Exception handling was initially omied in Go due to lack of a "design that gives value proportionate
to the complexity".[116] An exception-like panic/recover mechanism that avoids the usual try-
catch control structure was proposed[117] and released in the March 30, 2010 snapshot.[118] e Go
authors advise using it for unrecoverable errors such as those that should halt an entire program or
server request, or as a shortcut to propagate errors up the stack within a package.[119][120] Across
package boundaries, Go includes a canonical error type, and multi-value returns using this type are the
standard idiom.[4]
Style
e Go authors put substantial effort into influencing the style of Go programs:
9 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
Tools
e main Go distribution includes tools for building, testing, and analyzing code:
▪ go build, which builds Go binaries using only information in the source files
themselves, no separate makefiles
▪ go test, for unit testing and microbenchmarks as well as fuzzing
▪ go fmt, for formatting code
▪ go install, for retrieving and installing remote packages
▪ go vet, a static analyzer looking for potential errors in code
▪ go run, a shortcut for building and executing code
▪ godoc, for displaying documentation or serving it via HTTP
▪ gorename, for renaming variables, functions, and so on in a type-safe way
▪ go generate, a standard way to invoke code generators
▪ go mod, for creating a new module, adding dependencies, upgrading dependencies,
etc.
It also includes profiling and debugging support, fuzzing capabilities to detect bugs, runtime
instrumentation (for example, to track garbage collection pauses), and a data race detector.
Another tool maintained by the Go team but is not included in Go distributions is gopls, a language
server that provides IDE features such as intelligent code completion to Language Server Protocol
compatible editors.[129]
An ecosystem of third-party tools adds to the standard distribution, such as gocode, which enables
code autocompletion in many text editors, goimports, which automatically adds/removes package
imports as needed, and errcheck, which detects code that might unintentionally ignore errors.
Examples
Hello world
package main
import "fmt"
func main() {
fmt.Println("hello world")
10 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
where "fmt" is the package for formaed I/O, similar to C's C file input/output.[130]
Concurrency
e following simple program demonstrates Go's concurrency features to implement an asynchronous
program. It launches two lightweight threads ("goroutines"): one waits for the user to type some text,
while the other implements a timeout. e select statement waits for either of these goroutines to
send a message to the main routine, and acts on the first message to arrive (example adapted from
David Chisnall's book).[94]:152
package main
import (
"fmt"
"time"
)
func main() {
t := make(chan bool)
go timeout(t)
ch := make(chan string)
go readword(ch)
select {
case word := <-ch:
fmt.Println("Received", word)
case <-t:
fmt.Println("Timeout.")
}
}
Testing
e testing package provides support for automated testing of go packages.[131] Target function
example:
Test code (note that assert keyword is missing in Go; tests live in <filename>_test.go at the same
package):
import (
"testing"
)
11 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
Web app
e net/hp package provides support for creating web applications.
package main
import (
"fmt"
"log"
"net/http"
)
func main() {
http.HandleFunc("/", helloFunc)
log.Fatal(http.ListenAndServe(":8080", nil))
}
Applications
Go has found widespread adoption in various domains due to its robust standard library and ease of
use.[132]
Popular applications include: Caddy, a web server that automates the process of seing up HTTPS,[133]
Docker, which provides a platform for containerization, aiming to ease the complexities of soware
development and deployment,[134] Kubernetes, which automates the deployment, scaling, and
management of containerized applications,[135] CockroachDB, a distributed SQL database engineered
for scalability and strong consistency,[136] and Hugo, a static site generator that prioritizes speed and
flexibility, allowing developers to create websites efficiently.[137]
For further examples, please also see related query to Wikidata (hps://query.wikidata.org/#SELECT%2
0DISTINCT%20%3Finstance_of%20%3Finstance_ofDescription%20%3Finstance_ofLabel%20%3Fofficial_w
ebsite%0AWHERE%20%7B%0A%20%20SERVICE%20wikibase%3Alabel%20%7B%20bd%3AserviceParam%
20wikibase%3Alanguage%20%22%5BAUTO_LANGUAGE%5D%2Cen%22.%20%7D%0A%20%20%3Finstanc
e_of%20wdt%3AP31%2Fwdt%3AP279%2a%20wd%3AQ341%0A%20%20OPTIONAL%20%7B%20%3Finstanc
e_of%20wdt%3AP856%20%3Fofficial_website%20%7D%0A%20%20%3Finstance_of%20wdt%3AP277%20w
12 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
d%3AQ37227.%0A%7D)
Reception
e interface system, and the deliberate omission of inheritance, were praised by Michele Simionato,
who likened these characteristics to those of Standard ML, calling it "a shame that no popular language
has followed [this] particular route".[138]
Go is extremely easy to dive into. ere are a minimal number of fundamental language
concepts and the syntax is clean and designed to be clear and unambiguous. Go is still
experimental and still a lile rough around the edges.
Go was named Programming Language of the Year by the TIOBE Programming Community Index in its
first year, 2009, for having a larger 12-month increase in popularity (in only 2 months, aer its
introduction in November) than any other language that year, and reached 13th place by January
2010,[140] surpassing established languages like Pascal. By June 2015, its ranking had dropped to below
50th in the index, placing it lower than COBOL and Fortran.[141] But as of January 2017, its ranking had
surged to 13th, indicating significant growth in popularity and adoption. Go was again awarded TIOBE
Programming Language of the Year in 2016.
e complexity of C++ (even more complexity has been added in the new C++), and the
resulting impact on productivity, is no longer justified. All the hoops that the C++
programmer had to jump through in order to use a C-compatible language make no sense
anymore -- they're just a waste of time and effort. Go makes much more sense for the class of
problems that C++ was originally intended to solve.
A 2011 evaluation of the language and its gc implementation in comparison to C++ (GCC), Java and
Scala by a Google engineer found:
Go offers interesting language features, which also allow for a concise and standardized
notation. e compilers for this language are still immature, which reflects in both
performance and binary sizes.
—R. Hundt[143]
e evaluation got a rebual from the Go development team. Ian Lance Taylor, who had improved the
Go code for Hundt's paper, had not been aware of the intention to publish his code, and says that his
version was "never intended to be an example of idiomatic or efficient Go"; Russ Cox then optimized
the Go code, as well as the C++ code, and got the Go code to run almost as fast as the C++ version and
more than an order of magnitude faster than the code in the paper.[144]
▪ Go's nil combined with the lack of algebraic types leads to difficulty handling failures
and base cases.[145][146]
13 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
▪ Go does not allow an opening brace to appear on its own line, which forces all Go
programmers to use the same brace style.[147]
▪ Go has been criticized for focusing on simplicity of implementation rather than
correctness and flexibility; as an example, the language uses POSIX file semantics on
all platforms, and therefore provides incorrect information on platforms such as
Windows (which do not follow the aforementioned standard).[148][149]
▪ A study showed that it is as easy to make concurrency bugs with message passing as
with shared memory, sometimes even more.[150]
Naming dispute
On November 10, 2009, the day of the general release of the language, Francis McCabe, developer of the
Go! programming language (note the exclamation point), requested a name change of Google's
language to prevent confusion with his language, which he had spent 10 years developing.[151] McCabe
raised concerns that "the 'big guy' will end up steam-rollering over" him, and this concern resonated
with the more than 120 developers who commented on Google's official issues thread saying they
should change the name, with some[152] even saying the issue contradicts Google's moo of: Don't be
evil.[153]
On October 12, 2010, the filed public issue ticket was closed by Google developer Russ Cox (@rsc) with
the custom status "Unfortunate" accompanied by the following comment:
"ere are many computing products and services named Go. In the 11 months since our
release, there has been minimal confusion of the two languages."[153]
See also
Free and open-
source software
portal
▪ Fat pointer
▪ Comparison of programming languages
Notes
a. Using alternative backends reduces compilation speed and Go's control over garbage
collection but provides better machine-code optimization.[20]
b. But "To allow complex statements to occupy a single line, a semicolon may be omitted
before a closing ) or }".[55]
c. "if the newline comes after a token that could end a statement, [the lexer will] insert a
semicolon".[56]
d. Usually, exactly one of the result and error values has a value other than the type's
zero value; sometimes both do, as when a read or write can only be partially
completed, and sometimes neither, as when a read returns 0 bytes. See Semipredicate
problem: Multivalued return.
e. Language FAQ "Why is there no pointer arithmetic? Safety ... never derive an illegal
14 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
address that succeeds incorrectly ... using array indices can be as efficient as ... pointer
arithmetic ... simplify the implementation of the garbage collector...."[4]
f. Language FAQ "Why does Go not have assertions? ...our experience has been that
programmers use them as a crutch to avoid thinking about proper error handling and
reporting...."[4]
g. Language FAQ "Why are there no untagged unions...? [they] would violate Go's
memory safety guarantees."[4]
h. Language FAQ "Why does Go not have variant types? ... We considered [them but] they
overlap in confusing ways with interfaces.... [S]ome of what variant types address is
already covered, ... although not as elegantly."[4] (The tag of an interface type[113] is
accessed with a type assertion[114]).
i. Questions "How do I get dynamic dispatch of methods?" and "Why is there no type
inheritance?" in the language FAQ.[4]
References
1. "Codewalk: First-Class Functions in Go" (https://go.dev/doc/codewalk/functions/). "Go
supports first class functions, higher-order functions, user-defined function types,
function literals, closures, and multiple return values. This rich feature set supports a
functional programming style in a strongly typed language."
2. "Is Go an object-oriented language?" (https://golang.org/doc/faq#Is_Go_an_object-orie
nted_language). Retrieved April 13, 2019. "Although Go has types and methods and
allows an object-oriented style of programming, there is no type hierarchy."
3. "Go: code that grows with grace" (https://talks.golang.org/2012/chat.slide#5).
Retrieved June 24, 2018. "Go is Object Oriented, but not in the usual way."
4. "Language Design FAQ" (https://golang.org/doc/go_faq.html). The Go Programming
Language. January 16, 2010. Retrieved February 27, 2010.
5. "Text file LICENSE" (https://golang.org/LICENSE). The Go Programming Language.
Retrieved October 5, 2012.
6. "Release History" (https://go.dev/doc/devel/release#go1.22.0).
7. "The Go Programming Language Specification - the Go Programming Language" (http
s://go.dev/ref/spec#Introduction).
8. "Why doesn't Go have "implements" declarations?" (https://golang.org/doc/faq#imple
ments_interface). The Go Programming Language. Retrieved October 1, 2015.
9. Pike, Rob (December 22, 2014). "Rob Pike on Twitter" (https://web.archive.org/web/202
20407025913/https://twitter.com/rob_pike/status/546973312543227904). Archived
from the original (https://twitter.com/rob_pike/status/546973312543227904) on April 7,
2022. Retrieved March 13, 2016. "Go has structural typing, not duck typing. Full
interface satisfaction is checked and required."
10. "lang/go: go-1.4" (http://ports.su/lang/go). OpenBSD ports. December 23, 2014.
Retrieved January 19, 2015.
11. "Go Porting Efforts" (http://go-lang.cat-v.org/os-ports). Go Language Resources. cat-v.
January 12, 2010. Retrieved January 18, 2010.
12. "Additional IP Rights Grant" (https://golang.org/PATENTS). The Go Programming
Language. Retrieved October 5, 2012.
13. Kincaid, Jason (November 10, 2009). "Google's Go: A New Programming Language
That's Python Meets C++" (https://techcrunch.com/2009/11/10/google-go-language/).
TechCrunch. Retrieved January 18, 2010.
14. Metz, Cade (May 5, 2011). "Google Go boldly goes where no code has gone before" (htt
ps://www.theregister.co.uk/2011/05/05/google_go/). The Register.
15 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
16 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
17 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
18 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
19 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
20 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
21 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
138. Simionato, Michele (November 15, 2009). "Interfaces vs Inheritance (or, watch out for
Go!)" (http://www.artima.com/weblogs/viewpost.jsp?thread=274019). artima. Retrieved
November 15, 2009.
139. Astels, Dave (November 9, 2009). "Ready, Set, Go!" (https://web.archive.org/web/20181
019164102/https://www.engineyard.com/blog/ready-set-go). engineyard. Archived
from the original (https://www.engineyard.com/blog/ready-set-go) on October 19,
2018. Retrieved November 9, 2009.
140. jt (January 11, 2010). "Google's Go Wins Programming Language Of The Year Award" (h
ttp://jaxenter.com/google-s-go-wins-programming-language-of-the-year-award-10069.
html). jaxenter. Retrieved December 5, 2012.
141. "TIOBE Programming Community Index for June 2015" (http://www.tiobe.com/index.p
hp/content/paperinfo/tpci/index.html). TIOBE Software. June 2015. Retrieved July 5,
2015.
142. Eckel, Bruce (August 27, 2011). "Calling Go from Python via JSON-RPC" (http://www.arti
ma.com/weblogs/viewpost.jsp?thread=333589). Retrieved August 29, 2011.
143. Hundt, Robert (2011). Loop recognition in C++/Java/Go/Scala (https://days2011.scala-lan
g.org/sites/days2011/files/ws3-1-Hundt.pdf) (PDF). Scala Days.
144. Metz, Cade (July 1, 2011). "Google Go strikes back with C++ bake-off" (https://www.ther
egister.co.uk/2011/07/01/go_v_cpluplus_redux/). The Register.
145. Yager, Will. "Why Go is not Good" (http://yager.io/programming/go.html). Retrieved
November 4, 2018.
146. Dobronszki, Janos. "Everyday Hassles in Go" (https://crufter.com/everyday-hassles-in-g
o). Retrieved November 4, 2018.
147. "Why are there braces but no semicolons? And why can't I put the opening brace on
the next line?" (https://golang.org/doc/faq#semicolons). Retrieved March 26, 2020.
"The advantages of a single, programmatically mandated format for all Go programs
greatly outweigh any perceived disadvantages of the particular style."
148. "I want off Mr. Golang's Wild Ride" (https://fasterthanli.me/articles/i-want-off-mr-golan
gs-wild-ride). February 28, 2020. Retrieved November 17, 2020.
149. "proposal: os: Create/Open/OpenFile() set FILE_SHARE_DELETE on windows #32088" (ht
tps://github.com/golang/go/issues/32088). GitHub. May 16, 2019. Retrieved
November 17, 2020.
150. Tu, Tengfei (2019). "Understanding Real-World Concurrency Bugs in Go" (https://songl
h.github.io/paper/go-study.pdf) (PDF). "For example, around 58% of blocking bugs are
caused by message passing. In addition to the violation of Go's channel usage rules
(e.g., waiting on a channel that no one sends data to or close), many concurrency bugs
are caused by the mixed usage of message passing and other new semantics and new
libraries in Go, which can easily be overlooked but hard to detect"
151. Brownlee, John (November 13, 2009). "Google didn't google "Go" before naming their
programming language' " (https://web.archive.org/web/20151208143907/http://www.g
eek.com/news/google-didnt-google-go-before-naming-their-programming-language-9
77351/). Archived from the original (http://www.geek.com/news/google-didnt-google-g
o-before-naming-their-programming-language-977351/) on December 8, 2015.
Retrieved May 26, 2016.
152. Claburn, Thomas (November 11, 2009). "Google 'Go' Name Brings Accusations Of Evil' "
(https://web.archive.org/web/20100722010320/http://www.informationweek.com/new
s/software/web_services/showArticle.jhtml?articleID=221601351). InformationWeek.
Archived from the original (http://www.informationweek.com/news/software/web_serv
ices/showArticle.jhtml?articleID=221601351) on July 22, 2010. Retrieved January 18,
2010.
22 of 23 5/9/24, 21:14
Go (programming language) - Wikipedia https://en.wikipedia.org/wiki/Go_(programming_language)
153. "Issue 9 - go — I have already used the name for *MY* programming language" (http
s://github.com/golang/go/issues/9#issuecomment-66047478). Github. Google Inc.
Retrieved October 12, 2010.
Further reading
▪ Donovan, Alan; Kernighan, Brian (October 2015). The Go Programming Language (http
s://www.informit.com/store/go-programming-language-9780134190440) (1st ed.).
Addison-Wesley Professional. p. 400. ISBN 978-0-13-419044-0.
▪ Bodner, Jon (March 2021). Learning Go (https://www.oreilly.com/library/view/learning-g
o/9781492077206/) (1st ed.). O'Reilly. p. 352. ISBN 9781492077213.
External links
▪ Official website (https://go.dev)
23 of 23 5/9/24, 21:14