Английская Википедия:Go (programming language)
Шаблон:Short description
Шаблон:For
Шаблон:Other uses
Шаблон:Use American English
Шаблон:Use mdy dates
Шаблон:Infobox programming language
Go is a statically typed, compiled high-level programming language designed at Google[1] by Robert Griesemer, Rob Pike, and Ken Thompson.[2] It is syntactically similar to C, but also has memory safety, garbage collection, structural typing,[3] and CSP-style concurrency.[4] It is often referred to as Golang because of its former domain name, golang.org
, but its proper name is Go.[5]
There are two major implementations:
- Google's self-hosting[6] "gc" compiler toolchain, targeting multiple operating systems and WebAssembly.[7]
- gofrontend, a frontend to other compilers, with the libgo library. With GCC the combination is gccgo;[8] with LLVM the combination is gollvm.[9]Шаблон:Efn
A third-party source-to-source compiler, GopherJS,[10] compiles Go to JavaScript for front-end web development. Шаблон:Toclimit
History
Go was designed at Google in 2007 to improve programming productivity in an era of multicore, networked machines and large codebases.[11] The designers wanted to address criticisms of other languages in use at Google, but keep their useful characteristics:[12]
- Static typing and run-time efficiency (like C)
- Readability and usability (like Python)[13]
- High-performance networking and multiprocessing
Its designers were primarily motivated by their shared dislike of C++.[14][15][16]
Go was publicly announced in November 2009,[17] and version 1.0 was released in March 2012.[18][19] Go is widely used in production at Google[20] and in many other organizations and open-source projects.
Branding and styling
The Gopher mascot was introduced in 2009 for the open source launch of the language. The design, by Renée French, borrowed from a c. 2000 WFMU promotion.[21]
In November 2016, the Go and Go Mono fonts were released by type designers Charles Bigelow and Kris Holmes specifically for use by the Go project. Go is a humanist sans-serif resembling Lucida Grande, and Go Mono is monospaced. Both fonts adhere to the WGL4 character set and were designed to be legible with a large x-height and distinct letterforms. Both Go and Go Mono adhere to the DIN 1450 standard by having a slashed zero, lowercase l
with a tail, and an uppercase I
with serifs.[22][23]
In April 2018, the original logo was redesigned by brand designer Adam Smith. The new logo is a modern, stylized GO slanting right with trailing streamlines. (The Gopher mascot remained the same.[24])
Generics
The lack of support for generic programming in initial versions of Go drew considerable criticism.[25] The designers expressed an openness to generic programming and noted that built-in functions were in fact type-generic, but are treated as special cases; Pike called this a weakness that might be changed at some point.[26] The Google team built at least one compiler for an experimental Go dialect with generics, but did not release it.[27]
In August 2018, the Go principal contributors published draft designs for generic programming and error handling and asked users to submit feedback.[28][29] However, the error handling proposal was eventually abandoned.[30]
In June 2020, a new draft design document[31] was published that would add the necessary syntax to Go for declaring generic functions and types. A code translation tool, Шаблон:Mono, was provided to allow users to try the new syntax, along with a generics-enabled version of the online Go Playground.[32]
Generics were finally added to Go in version 1.18.[33]
Versioning
Go 1 guarantees compatibility[34] for the language specification and major parts of the standard library. All versions up to the current Go 1.21 release[35] have maintained this promise.
Each major Go release is supported until there are two newer major releases.[36]
Design
Go is influenced by C (especially the Plan 9 dialect[37]Шаблон:Failed verification), but with an emphasis on greater simplicity and safety. It consists of:
- A syntax and environment adopting patterns more common in dynamic languages:[38]
- Optional concise variable declaration and initialization through type inference (
x := 0
instead ofvar x int = 0;
orvar x = 0;
) - Fast compilation[39]
- Remote package management (
go get
)[40] and online package documentation[41]
- Optional concise variable declaration and initialization through type inference (
- Distinctive approaches to particular problems:
- Built-in concurrency primitives: light-weight processes (goroutines), channels, and the
select
statement - An interface system in place of virtual inheritance, and type embedding instead of non-virtual inheritance
- A toolchain that, by default, produces statically linked native binaries without external Go dependencies
- Built-in concurrency primitives: light-weight processes (goroutines), channels, and the
- A desire to keep the language specification simple enough to hold in a programmer's head,[42] in part by omitting features that are common in similar languages.
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. This contrasts with C's int i = 3;
and const char *s = "Hello, world!";
.
Semicolons still terminate statements;Шаблон:Efn but are implicit when the end of a line occurs.Шаблон:Efn
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.Шаблон:Efn 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.[43]
Types
Go has a number of built-in types, including numeric ones (Шаблон:Mono, Шаблон:Mono, Шаблон:Mono, etc.), booleans, and byte strings (Шаблон:Mono). Strings are immutable; built-in operators and keywords (rather than functions) provide concatenation, comparison, and UTF-8 encoding/decoding.[44] Record types can be defined with the Шаблон:Mono keyword.[45]
For each type Шаблон:Mono and each non-negative integer constant Шаблон:Mono, there is an array type denoted Шаблон:Mono; arrays of differing lengths are thus of different types. Dynamic arrays are available as "slices", denoted Шаблон:Mono for some type Шаблон:Mono. These 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.Шаблон:R[46][47]
Pointers are available for all types, and the pointer-to-Шаблон:Mono type is denoted Шаблон:Mono. Address-taking and indirection use the Шаблон:Mono and Шаблон:Mono operators, as in C, or happen implicitly through the method call or attribute access syntax.[48][49] There is no pointer arithmetic,Шаблон:Efn except via the special Шаблон:Mono type in the standard library.[50]
For a pair of types Шаблон:Mono, Шаблон:Mono, the type Шаблон:Mono is the type mapping type-Шаблон:Mono keys to type-Шаблон:Mono 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. Шаблон:Mono is a channel that allows sending values of type T between concurrent Go processes.[51]
Aside from its support for interfaces, Go's type system is nominal: the Шаблон:Mono 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 Шаблон:Mono, 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.[52] For example, the Шаблон:Mono keyword can be used to define a type for IPv4 addresses, based on 32-bit unsigned integers as follows:
type ipv4addr uint32
With this type definition, Шаблон:Mono interprets the Шаблон:Mono value Шаблон:Mono as an IP address. Simply assigning Шаблон:Mono to a variable of type Шаблон:Mono is a type error.[53]
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.[54]
Function types are indicated by the Шаблон:Mono keyword; they take zero or more parameters and return zero or more values, all of which are typed. The parameter and return values determine a function type; thus, Шаблон:Mono is the type of functions that take a Шаблон:Mono and a 32-bit signed integer, and return a signed integer (of default width) and a value of the built-in interface type Шаблон:Mono.[55]
Any named type has a method set associated with it. The IP address example above can be extended with a method for checking whether its value is a known standard:
// ZeroBroadcast reports whether addr is 255.255.255.255.
func (addr ipv4addr) ZeroBroadcast() bool {
return addr == 0xFFFFFFFF
}
Due to nominal typing, this method definition adds a method to Шаблон:Mono, but not on Шаблон:Mono. While methods have special definition and call syntax, there is no distinct method type.[56]
Шаблон:Anchor Interface system
Go provides two features that replace class inheritance.Шаблон:Citation needed
The first is embedding, which can be viewed as an automated form of composition.Шаблон:R
The second are its interfaces, which provides runtime polymorphism.[57]Шаблон:Rp 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 after protocols from the Smalltalk programming language.[58] Multiple sources use the term duck typing when describing Go interfaces.[59][60] 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.[61]
The 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. The definition of type T need not (and cannot) identify type I. For example, if Шаблон:Mono, Шаблон:Mono Шаблон:Mono are defined as
import "math"
type Shape interface {
Area() float64
}
type Square struct { // Note: no "implements" declaration
side float64
}
func (sq Square) Area() float64 { return sq.side * sq.side }
type Circle struct { // No "implements" declaration here either
radius float64
}
func (c Circle) Area() float64 { return math.Pi * math.Pow(c.radius, 2) }
then both a Шаблон:Mono and a Шаблон:Mono are implicitly a Шаблон:Mono and can be assigned to a Шаблон:Mono-typed variable.Шаблон:RШаблон:Rp 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.Шаблон:RШаблон:Rp
The Go standard library uses interfaces to provide genericity in several places, including the input/output system that is based on the concepts of Шаблон:Mono and Шаблон:Mono.Шаблон:RШаблон:Rp
Besides calling methods via interfaces, Go allows converting interface values to other types with a run-time type check. The language constructs to do so are the type assertion,[62] which checks against a single potential type:
var shp Shape = Square{5}
square, ok := shp.(Square) // Asserts Square type on shp, should work
if ok {
fmt.Printf("%#v\n", square)
} else {
fmt.Println("Can't print shape as Square")
}
and the type switch,[63] which checks against multiple types:Шаблон:Citation needed
func (sq Square) Diagonal() float64 { return sq.side * math.Sqrt2 }
func (c Circle) Diameter() float64 { return 2 * c.radius }
func LongestContainedLine(shp Shape) float64 {
switch v := shp.(type) {
case Square:
return v.Diagonal() // Or, with type assertion, shp.(Square).Diagonal()
case Circle:
return v.Diameter() // Or, with type assertion, shp.(Circle).Diameter()
default:
return 0 // In practice, this should be handled with errors
}
}
The empty interface interface{}
is an important base case because it can refer to an item of any concrete type. It is similar to the Шаблон:Mono class in Java or C# and is satisfied by any type, including built-in types like Шаблон:Mono.Шаблон:RШаблон:Rp 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.[64] 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.Шаблон:Citation needed
The 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). This recursively describes data in the form of a dictionary with string keys and values of any type.[65]
Interface values are implemented using pointer to data and a second pointer to run-time type information.[66] Like some other types implemented using pointers in Go, interface values are nil
if uninitialized.[67]
Generic code using parameterized types
Since version 1.18, Go supports generic code using parameterized types.[68]
Functions and types now have the ability to be generic using type parameters. These type parameters are specified within square brackets, right after the function or type name.[69] The 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.[70] This transformation process is referred to as type instantiation.[71]
Interfaces now can define a set of types (known as type set) using |
(Union) operator, as well as a set of methods. These 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. This 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
.[72]
type Number interface {
~int | ~float64 | ~float32 | ~int32 | ~int64
}
func Add[T Number](nums ...T) T {
var sum T
for _, v := range nums {
sum += v
}
return sum
}
func main() {
add := Add[int] // Type instantiation
println(add(1, 2, 3, 4, 5)) // 15
res := Add(1.1, 2.2, 3.3, 4.4, 5.5) // Type Inference
println(res) // +1.650000e+001
}
Enumerated types
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.[73] The go get
command can retrieve packages stored in a remote repository[74] 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.[75]
Шаблон:Anchor Concurrency: goroutines and channels
The Go language has built-in facilities, as well as library support, for writing concurrent programs. Concurrency refers not only to CPU parallelism, but also to asynchrony: letting slow operations like a database or network read run while the program does other work, as is common in event-based servers.[76]
The primary concurrency construct is the goroutine, a type of green thread.[77]Шаблон:Rp A function call prefixed with the go
keyword starts a function in a new goroutine. The 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.Шаблон:RШаблон:Rp
While a standard library package featuring most of the classical concurrency control structures (mutex locks, etc.) is available,Шаблон:RШаблон:Rp idiomatic concurrent programs instead prefer channels, which send messages between goroutines.[78] Optional buffers store messages in FIFO order[79]Шаблон:Rp and allow sending goroutines to proceed before their messages are received.[77]Шаблон:Rp
Channels are typed, so that a channel of type Шаблон:Mono can only be used to transfer messages of type Шаблон:Mono. Special syntax is used to operate on them; Шаблон:Mono is an expression that causes the executing goroutine to block until a value comes in over the channel Шаблон:Mono, while Шаблон:Mono sends the value Шаблон:Mono (possibly blocking until another goroutine receives the value). The built-in Шаблон:Mono-like Шаблон:Mono 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.[80]
The 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. The 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.Шаблон:RШаблон:Rp
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.[81] Channels have also found uses further from the usual notion of interprocess communication, like serving as a concurrency-safe list of recycled buffers,[82] implementing coroutines (which helped inspire the name goroutine),[83] and implementing iterators.[84]
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),[85] Go does not provide any built-in notion of safe or verifiable concurrency.[86] 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. This means that mutable objects and pointers can be shared between goroutines; see Шаблон:Slink, below.
Suitability for parallel programming
Although Go's concurrency features are not aimed primarily at parallel processing,Шаблон:R they can be used to program shared-memory multi-processor machines. Various studies have been done into the effectiveness of this approach.[87] One of these studies compared the size (in lines of code) and speed of programs written by a seasoned programmer not familiar with the language and corrections to these programs by a Go expert (from Google's development team), doing the same for Chapel, Cilk and Intel TBB. The study found that the non-expert tended to write divide-and-conquer algorithms with one Шаблон:Mono statement per recursion, while the expert wrote distribute-work-synchronize programs using one goroutine per processor core. The expert's programs were usually faster, but also longer.[88]
Lack of data race safety
Go's approach to concurrency can be summarized as "don't communicate by sharing memory; share memory by communicating".[89] There are no restrictions on how goroutines access shared data, making data races possible. Specifically, unless a program explicitly synchronizes via channels or other means, writes from one goroutine might be partly, entirely, or not at all visible to another, often with no guarantees about ordering of writes.[86] Furthermore, Go's internal data structures like interface values, slice headers, hash tables, and string headers are not immune to data races, so type and memory safety can be violated in multithreaded programs that modify shared instances of those types without synchronization.[90][91] Instead of language support, safe concurrent programming thus relies on conventions; for example, Chisnall recommends an idiom called "aliases xor mutable", meaning that passing a mutable value (or pointer) over a channel signals a transfer of ownership over the value to its receiver.Шаблон:RШаблон:Rp The gc toolchain has an optional data race detector that can check for unsynchronized access to shared memory during runtime since version 1.1,[92] additionally a best-effort race detector is also included by default since version 1.6 of the gc runtime for access to the map
data type.[93]
Binaries
The linker in the gc toolchain creates statically linked binaries by default; therefore all Go binaries include the Go runtime.[94][95]
Omissions
Go deliberately omits certain features common in other languages, including (implementation) inheritance, assertions,Шаблон:Efn pointer arithmetic,Шаблон:Efn implicit type conversions, untagged unions,Шаблон:Efn and tagged unions.Шаблон:Efn The designers added only those facilities that all three agreed on.[96]
Of the omitted 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Шаблон:Efn and composition to reuse code. Composition and delegation are in fact largely automated by Шаблон:Mono 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.[97]
Exception handling was initially omitted in Go due to lack of a "design that gives value proportionate to the complexity".[98] An exception-like Шаблон:Mono/Шаблон:Mono mechanism that avoids the usual try-catch
control structure was proposed[99] and released in the March 30, 2010 snapshot.[100] The 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.[101][102] Across package boundaries, Go includes a canonical error type, and multi-value returns using this type are the standard idiom.[2]
Style
The Go authors put substantial effort into influencing the style of Go programs:
- Indentation, spacing, and other surface-level details of code are automatically standardized by the
gofmt
tool. It uses tabs for indentation and blanks for alignment. Alignment assumes that an editor is using a fixed-width font.[103]golint
does additional style checks automatically, but has been deprecated and archived by the Go maintainers.[104] - Tools and libraries distributed with Go suggest standard approaches to things like API documentation (
godoc
),[105] testing (go test
), building (go build
), package management (go get
), and so on. - Go enforces rules that are recommendations in other languages, for example banning cyclic dependencies, unused variables[106] or imports,[107] and implicit type conversions.
- The omission of certain features (for example, functional-programming shortcuts like
map
and Java-styletry
/finally
blocks) tends to encourage a particular explicit, concrete, and imperative programming style. - On day one the Go team published a collection of Go idioms,[105] and later also collected code review comments,[108] talks,[109] and official blog posts[110] to teach Go style and coding philosophy.
Tools
The 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 makefilesgo test
, for unit testing and microbenchmarks as well as fuzzinggo fmt
, for formatting codego install
, for retrieving and installing remote packagesgo vet
, a static analyzer looking for potential errors in codego run
, a shortcut for building and executing codegodoc
, for displaying documentation or serving it via HTTPgorename
, for renaming variables, functions, and so on in a type-safe waygo generate
, a standard way to invoke code generatorsgo 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.[111]
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")
}
where "fmt" is the package for formatted I/O, similar to C's C file input/output.[112]
Шаблон:AnchorConcurrency
The 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. The Шаблон:Mono 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).[113]Шаблон:Rp
package main
import (
"fmt"
"time"
)
func readword(ch chan string) {
fmt.Println("Type a word, then hit Enter.")
var word string
fmt.Scanf("%s", &word)
ch <- word
}
func timeout(t chan bool) {
time.Sleep(5 * time.Second)
t <- false
}
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
The testing package provides support for automated testing of go packages.[114] Target function example:
func ExtractUsername(email string) string {
at := strings.Index(email, "@")
return email[:at]
}
Test code (note that assert keyword is missing in Go; tests live in <filename>_test.go at the same package):
import (
"testing"
)
func TestExtractUsername(t *testing.T) {
t.Run("withoutDot", func(t *testing.T) {
username := ExtractUsername("r@google.com")
if username != "r" {
t.Fatalf("Got: %v\n", username)
}
})
t.Run("withDot", func(t *testing.T) {
username := ExtractUsername("jonh.smith@example.com")
if username != "jonh.smith" {
t.Fatalf("Got: %v\n", username)
}
})
}
It is possible to run tests in parallel.
Web app
The net/http package provides support for creating web applications.
This example would show "Hello world!" when localhost:8080 is visited.
package main
import (
"fmt"
"log"
"net/http"
)
func helloFunc(w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "Hello world!")
}
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.[115]
Popular applications include: Caddy, a web server that automates the process of setting up HTTPS,[116] Docker, which provides a platform for containerization, aiming to ease the complexities of software development and deployment,[117] Kubernetes, which automates the deployment, scaling, and management of containerized applications,[118] CockroachDB, a distributed SQL database engineered for scalability and strong consistency,[119] and Hugo, a static site generator that prioritizes speed and flexibility, allowing developers to create websites efficiently.[120]
For further examples, please also see related query to Wikidata
Reception
The 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".[121]
Dave Astels at Engine Yard wrote in 2009:[122] Шаблон:Blockquote
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, after its introduction in November) than any other language that year, and reached 13th place by January 2010,[123] 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.[124] 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.Шаблон:Cite needed
Bruce Eckel has stated:[125] Шаблон:Blockquote
A 2011 evaluation of the language and its Шаблон:Mono implementation in comparison to C++ (GCC), Java and Scala by a Google engineer found:
The evaluation got a rebuttal 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.[126]
- Go's nil combined with the lack of algebraic types leads to difficulty handling failures and base cases.[127][128]
- Go does not allow an opening brace to appear on its own line, which forces all Go programmers to use the same brace style.[129]
- 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).[130][131]
- A study showed that it is as easy to make concurrency bugs with message passing as with shared memory, sometimes even more.[132]
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.[133] 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[134] even saying the issue contradicts Google's motto of: Don't be evil.[135]
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:
"There are many computing products and services named Go. In the 11 months since our release, there has been minimal confusion of the two languages."[135]
See also
Notes
References
Further reading
External links
Шаблон:Prone to spam Шаблон:Programming languages Шаблон:Google FOSS Шаблон:Rob Pike navbox Шаблон:Ken Thompson navbox
- ↑ Шаблон:Cite news
- ↑ 2,0 2,1 Шаблон:Cite web
- ↑ Ошибка цитирования Неверный тег
<ref>
; для сносокstructural_typing
не указан текст - ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web Video available.
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite news
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite news
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite AV media
- ↑ Шаблон:Cite web See godoc.org for addresses and documentation of some packages.
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite book
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ 77,0 77,1 Шаблон:Cite book
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite book
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ 86,0 86,1 Шаблон:Cite web
- ↑ Шаблон:Cite conference
- ↑ Шаблон:Cite conference
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web "There is one important caveat: Go is not purely memory safe in the presence of concurrency."
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite interview
- ↑ Шаблон:Cite conference
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ 105,0 105,1 Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite book
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite magazine
- ↑ Шаблон:Cite magazine
- ↑ Шаблон:Cite magazine
- ↑ Шаблон:Cite magazine
- ↑ Шаблон:Cite conference
- ↑ Шаблон:Cite news
- ↑ Шаблон:Cite news
- ↑ Шаблон:Cite news
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite web
- ↑ Шаблон:Cite news
- ↑ Шаблон:Cite news
- ↑ 135,0 135,1 Шаблон:Cite web
- Английская Википедия
- Страницы с неработающими файловыми ссылками
- Go (programming language)
- American inventions
- C programming language family
- Concurrent programming languages
- Cross-platform free software
- Cross-platform software
- Free compilers and interpreters
- Google software
- High-level programming languages
- Procedural programming languages
- Programming languages
- Programming languages created in 2009
- Software using the BSD license
- Statically typed programming languages
- Systems programming languages
- Страницы, где используется шаблон "Навигационная таблица/Телепорт"
- Страницы с телепортом
- Википедия
- Статья из Википедии
- Статья из Английской Википедии
- Страницы с ошибками в примечаниях