Jump to content

Go (programming language): Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Go isn't memory-safe when there are data races, though slightly unclear just how unsafe (like, does the whole show segfault?)
Concurrency: go more into exactly what's meant by lack of safe concurrency; wordy but can cut later
Line 64: Line 64:
Goroutines are executed concurrently with other goroutines, including their caller. They do not necessarily run in separate threads, but a group of goroutines can be multiplexed onto multiple threads, allowing parallel execution. Execution control is moved between them by blocking them when sending or receiving messages over channels. Channels are [[Bounded-buffer problem|bounded buffers]], not network connections.
Goroutines are executed concurrently with other goroutines, including their caller. They do not necessarily run in separate threads, but a group of goroutines can be multiplexed onto multiple threads, allowing parallel execution. Execution control is moved between them by blocking them when sending or receiving messages over channels. Channels are [[Bounded-buffer problem|bounded buffers]], not network connections.


Goroutines can share data with other goroutines, making [[race conditions]] possible. Specifically, unless a program explicitly synchronizes via channels or mutexes, writes from one goroutine might be partly, entirely, or not at all visible to another, often with no guarantees about ordering of writes.<ref name="memmodel"/> Furthermore, Go's ''internal data structures'' like interface values, slice headers, and string headers are not immune to race conditions, so type and memory safety can be violated in multithreaded programs missing synchronization.<ref>Russ Cox, [http://research.swtch.com/gorace Off to the Races]</ref><ref>{{cite web |
Goroutines can share data with other goroutines. [[Race conditions]] can occur in concurrent Go programs. Concurrent Go programs are not [[memory safe]].<ref>{{cite web |
title=Go at Google: Language Design in the Service of Software Engineering |
title=Go at Google: Language Design in the Service of Software Engineering |
url=http://talks.golang.org/2012/splash.article |
url=http://talks.golang.org/2012/splash.article |
publisher=Google, Inc.}} "There is one important caveat: Go is not purely memory safe in the presence of concurrency."</ref>
publisher=Google, Inc.}} "There is one important caveat: Go is not purely memory safe in the presence of concurrency."</ref> Idiomatic Go minimizes sharing of data (and thus potential race conditions) by communicating over channels, and a race-condition tester is included in the standard distribution to help catch unsafe behavior. Still, it is important to realize that while Go provides ''building blocks'' that can be used to write correct, comprehensible concurrent code, arbitrary code isn't ''guaranteed'' to be safe.


Some concurrency-related structural conventions of Go ([[channel (programming)|channel]]s and alternative channel inputs) are derived from [[C. A. R. Hoare|Tony Hoare's]] [[communicating sequential processes]] model. Unlike previous concurrent programming languages such as [[Occam (programming language)|occam]] or [[Limbo (programming language)|Limbo]], Go does not provide any built-in notion of safe or verifiable concurrency.<ref name="memmodel">{{cite web| url = http://golang.org/doc/go_mem.html | title = The Go Memory Model | publisher = Google | accessdate =5 January 2011}}</ref>
Some concurrency-related structural conventions of Go ([[channel (programming)|channel]]s and alternative channel inputs) are derived from [[C. A. R. Hoare|Tony Hoare's]] [[communicating sequential processes]] model. Unlike previous concurrent programming languages such as [[Occam (programming language)|occam]] or [[Limbo (programming language)|Limbo]] (a language on which Go co-designer Rob Pike worked<ref>Brian W. Kernighan, [http://www.vitanuova.com/inferno/papers/descent.html A Descent Into Limbo]</ref>), Go does not provide any built-in notion of safe or verifiable concurrency.<ref name="memmodel">{{cite web| url = http://golang.org/doc/go_mem.html | title = The Go Memory Model | publisher = Google | accessdate =5 January 2011}}</ref>


==Interface system==
==Interface system==

Revision as of 03:02, 10 October 2013

Template:Distinguish2

Go
Paradigmcompiled, concurrent, imperative, structured
Designed byRobert Griesemer
Rob Pike
Ken Thompson
DeveloperGoogle Inc.
First appeared2009
Stable release
version 1.1.2[1] / 13 August 2013; 11 years ago (2013-08-13)
Typing disciplinestrong, static
OSLinux, Mac OS X, FreeBSD, NetBSD, OpenBSD, MS Windows, Plan 9[2]
LicenseBSD-style[3] + Patent grant[4]
Filename extensions.go
Websitegolang.org
Major implementations
gc (8g, 6g, 5g), gccgo
Influenced by
C, Limbo, Modula, Newsqueak, Oberon, Pascal,[5] Python

Go, or golang, is a programming language It designed and developed at Google Inc.[6] beginning in September 2007 by Robert Griesemer, Rob Pike, and Ken Thompson.[5] It is a statically-typed language with syntax loosely derived from that of C, adding automatic memory management, type safety, some dynamic-typing capabilities, additional types such as variable-length arrays and key-value maps, and a large standard library. Beyond that broad categorization, Go is defined by:

The language was officially announced in November 2009 and is now used in some of Google's production systems.[12] Go's "gc" compiler targets the Linux, Mac OS X, FreeBSD, OpenBSD, Plan 9, and Microsoft Windows operating systems and the i386, amd64, and ARM processor architectures.[13]

Syntax and package system

Go's syntax, while recognizably in the C family, makes many changes aimed at keeping code concise. The Go compiler infers the types of expressions, allowing just i := 3 or w := "some words" to replace C's int i = 3; or char* s = "some words";. When a variable or struct field isn't explicitly initialized (e.g., var x, y, z int), the compiler gives it a type-appropriate zero value like 0, nil, or "". Semicolons at the end of lines aren't required. Functions may return multiple, named values, and returning a result, err pair is the standard way to handle errors in Go. (The language does have an exception-like mechanism, panic/recover, but it's intentionally cumbersome and only meant for rare circumstances.[14][15])

Go also adds syntax to support facilities that aren't in C. The interface system adds type assertions (str := iface.(string)) and type switches (switch iface.(type) {...}). For concurrency, the go statement starts a lightweight process, the <- operator tries to communicate over a channel, and the select statement tries to communicate on multiple channels. Go adds syntax for array slices, so that, for example, a[:3] refers to the first three items of array a. As in many C-family languages, function definitions can appear in expressions and close over any variables in the surrounding scope.

Go has a standard style covering indentation, spacing, and many other details, usually applied to user code by the go fmt tool in the Go distribution. Go requires that programs not contain unused variables or imports or discard the results of evaluating certain built-in functions.[16] Banning unnecessary imports is particularly important because Go does not support circular dependencies.

There is much more to Go's syntax; for further reading, try Go's language specification, the official language tour, and the Effective Go document, as well as the community-written gobyexample.com.

In Go's package system, each package has a path (e.g., "compress/bzip2" or "code.google.com/p/go.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 modules are accessible: io.Reader is public but bzip2.reader is not.[17] The go get command can retrieve packages stored in a remote repository such as Github or Google Code.[18]

Go deliberately omits certain features common in other languages, including generic programming, assertions, pointer arithmetic, and inheritance. The Go authors express an openness to generic programming, explicitly argue against assertions and pointer arithmetic, while defending the choice to omit type inheritance as giving a more useful language, encouraging heavy use of interfaces instead.[5]

Concurrency

Go provides goroutines, small lightweight threads; the name alludes to coroutines. Goroutines are created with the go statement from anonymous or named functions.

Goroutines are executed concurrently with other goroutines, including their caller. They do not necessarily run in separate threads, but a group of goroutines can be multiplexed onto multiple threads, allowing parallel execution. Execution control is moved between them by blocking them when sending or receiving messages over channels. Channels are bounded buffers, not network connections.

Goroutines can share data with other goroutines, making race conditions possible. Specifically, unless a program explicitly synchronizes via channels or mutexes, writes from one goroutine might be partly, entirely, or not at all visible to another, often with no guarantees about ordering of writes.[19] Furthermore, Go's internal data structures like interface values, slice headers, and string headers are not immune to race conditions, so type and memory safety can be violated in multithreaded programs missing synchronization.[20][21] Idiomatic Go minimizes sharing of data (and thus potential race conditions) by communicating over channels, and a race-condition tester is included in the standard distribution to help catch unsafe behavior. Still, it is important to realize that while Go provides building blocks that can be used to write correct, comprehensible concurrent code, arbitrary code isn't guaranteed to be safe.

Some 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[22]), Go does not provide any built-in notion of safe or verifiable concurrency.[19]

Interface system

In place of virtual inheritance, Go uses interfaces. An interface declaration is a list of required methods: for example, the interface io.Reader just requires the method Read(p []byte) (n int, err error).[23] Code that uses an io.Reader could potentially read from an HTTP connection, a file, an in-memory buffer, or any other source.

Go's standard library defines interfaces for a number of concepts: input sources and output sinks, sortable collections, objects printable as strings, cryptographic hashes, and so on.

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,[24] which checks against a single potential type, and the type switch,[25] which checks against multiple types.

Go types don't declare which interfaces they implement: having the required methods is implementing the interface.

interface{}, the empty interface, is an important corner case because it can refer to an item of any concrete type. Code using the empty interface can't 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.[26] Because interface{} can refer to any value, it's a limited way to escape the restrictions of static typing, like void* in C but with additional run-time type checks.

Go does not have interface inheritance, but one interface type can embed another; then the embedding interface requires all of the methods required by the embedded interface.[27]

The example below uses the io.Reader and io.Writer interfaces to test Go's implementation of SHA-256 on a standard test input, 1,000,000 repetitions of the character "a". RepeatChar implements an io.Reader yielding an infinite stream of repeats of a byte, similar to Unix /dev/zero. The main() function uses RepeatChar to stream a million repeats of "a" into the hash function, then prints the result, which can be compared to copies of NIST's test vectors online.[28] Notably, even though both reader and writer interfaces are needed to make this work, it's not necessary to declare what implements what; that's entirely inferred by the compiler:

package main
 
import (
        "fmt"
        "io"
	"crypto/sha256"
)
 
type RepeatChar byte
 
func (r RepeatChar) Read(p []byte) (n int, err error) {
        for i := range p {
                p[i] = byte(r)
        }
        return len(p), nil
}
 
func main() {
        testStream := RepeatChar('a')
	hasher := sha256.New()
        io.CopyN(hasher, testStream, 1000000)
        fmt.Printf("%x", hasher.Sum(nil))
}

(You can run or edit this example online.)

Interface values are stored in memory as a pointer to data and a second pointer to run-time type information.[29] Like other pointers in Go, interface values are nil if uninitialized.[30] Unlike in environments like Java's virtual machine, there is no object header; the run-time type information is only attached to interface values. So, the system imposes no per-object memory overhead for objects not accessed via interface, similar to C structs or C# ValueTypes.

Implementations

There are currently two major Go compilers available for Unix variants and Windows:

  • 6g/8g/5g (the compilers for AMD64, x86, and ARM respectively) with their supporting tools (collectively known as "gc") based on Thompson's previous work on Plan 9's C toolchain.
  • gccgo, a GCC frontend written in C++,[31] and now officially supported as of version 4.6, albeit not part of the standard binary for gcc.[32]

Examples

Hello world

The following is a Hello world program in Go:

package main

import "fmt"

func main() {
    fmt.Println("Hello, World")
}

(Run or edit this example online.)

Go's automatic semicolon insertion feature requires that opening braces not be placed on their own lines, and this is thus the preferred brace style. The examples shown comply with this style.[33]

Echo

Example illustrating how to write a program like the Unix echo command in Go:[34]

package main

import (
    "flag"
    "fmt"
    "strings"
)

func main() {
    var omitNewline bool
    flag.BoolVar(&omitNewline, "n", false, "don't print final newline")
    flag.Parse() // Scans the arg list and sets up flags.

    str := strings.Join(flag.Args(), " ")
    if omitNewline {
        fmt.Print(str)
    } else {
        fmt.Println(str)
    }
}

Reception

Go's initial release led to much discussion.

Michele Simionato wrote in an article for artima.com:[35]

Here I just wanted to point out the design choices about interfaces and inheritance. Such ideas are not new and it is a shame that no popular language has followed such particular route in the design space. I hope Go will become popular; if not, I hope such ideas will finally enter in a popular language, we are already 10 or 20 years too late :-(

Dave Astels at Engine Yard wrote:[36]

Go is extremely easy to dive into. There 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 little rough around the edges.

Ars Technica interviewed Rob Pike, one of the authors of Go, and asked why a new language was needed. He replied that:[37]

It wasn't enough to just add features to existing programming languages, because sometimes you can get more in the long run by taking things away. They wanted to start from scratch and rethink everything. ... [But they did not want] to deviate too much from what developers already knew because they wanted to avoid alienating Go's target audience.

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,[38] surpassing established languages like Pascal. As of March 2013, it ranked 24th in the index.[39] Go is already in commercial use by several large organizations.[40]

Bruce Eckel stated:[41]

The 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. Now, Go makes much more sense for the class of problems that C++ was originally intended to solve.

Mascot

Go's mascot is a gopher designed by Renée French, who also designed Glenda, the Plan 9 Bunny. The logo and mascot are licensed under Creative Commons Attribution 3.0 license.[42]

Naming dispute

On 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.[43] The issue was closed by a Google developer on 12 October 2010 with the custom status "Unfortunate" and with 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."[44]

See also

References

  1. ^ Google+ The Go Programming Language
  2. ^ "Go Porting Efforts". Go Language Resources. cat-v. 12 January 2010. Retrieved 18 January 2010.
  3. ^ "Text file LICENSE". The Go Programming Language. Google. Retrieved 5 October 2012.
  4. ^ "Additional IP Rights Grant". The Go Programming Language. Google. Retrieved 5 October 2012.
  5. ^ a b c "Language Design FAQ". golang.org. 16 January 2010. Retrieved 27 February 2010.
  6. ^ Kincaid, Jason (10 November 2009). "Google's Go: A New Programming Language That's Python Meets C++". TechCrunch. Retrieved 18 January 2010.
  7. ^ Pike, Rob. "The Go Programming Language". YouTube. Retrieved 1 July 2011.
  8. ^ Rob Pike (10 November 2009). The Go Programming Language (flv) (Tech talk). Google. Event occurs at 8:53.
  9. ^ Download and install packages and dependencies - go - The Go Programming Language; see [godoc.org] for addresses and documentation of some packages
  10. ^ Rob Pike, on The Changelog podcast
  11. ^ Rob Pike, Less is exponentially more
  12. ^ "Go FAQ: Is Google using Go internally?". Retrieved 9 March 2013.
  13. ^ "Installing Go". golang.org. The Go Authors. 11 June 2010. Retrieved 11 June 2010.
  14. ^ Release notes, 30 March 2010
  15. ^ "Proposal for an exception-like mechanism". golang-nuts. 25 March 2010. Retrieved 25 March 2010.
  16. ^ Expression statements - The Go Programming Language Specification
  17. ^ "A Tutorial for the Go Programming Language". The Go Programming Language. Google. Retrieved 10 March 2013. In Go the rule about visibility of information is simple: if a name (of a top-level type, function, method, constant or variable, or of a structure field or method) is capitalized, users of the package may see it. Otherwise, the name and hence the thing being named is visible only inside the package in which it is declared.
  18. ^ Download and install packages and dependencies - go - The Go Programming Language
  19. ^ a b "The Go Memory Model". Google. Retrieved 5 January 2011.
  20. ^ Russ Cox, Off to the Races
  21. ^ "Go at Google: Language Design in the Service of Software Engineering". Google, Inc. "There is one important caveat: Go is not purely memory safe in the presence of concurrency."
  22. ^ Brian W. Kernighan, A Descent Into Limbo
  23. ^ Reader - io - The Go Programming Language
  24. ^ Type Assertions - The Go Language Specification
  25. ^ Type switches - The Go Language Specification
  26. ^ reflect.ValueOf(i interface{}) converts an interface{} to a reflect.Value that can be further inspected
  27. ^ "Effective Go - Interfaces and methods & Embedding". Google. Retrieved 28 November 2011.
  28. ^ SHA-256 test vectors, set 1, vector #8
  29. ^ "Go Data Structures: Interfaces". Retrieved 15 November 2012.
  30. ^ Interface types - The Go Programming Language Specification
  31. ^ "FAQ: Implementation". golang.org. 16 January 2010. Retrieved 18 January 2010.
  32. ^ "Installing GCC: Configuration". Retrieved 3 December 2011. Ada, Go and Objective-C++ are not default languages
  33. ^ "A Tutorial for the Go Programming Language". The Go Programming Language. Google. Retrieved 10 March 2010. The one surprise is that it's important to put the opening brace of a construct such as an if statement on the same line as the if; however, if you don't, there are situations that may not compile or may give the wrong result. The language forces the brace style to some extent.
  34. ^ "A Tutorial for the Go Programming Language". golang.org. 16 January 2010. Retrieved 18 January 2010.
  35. ^ Simionato, Michele (15 November 2009). "Interfaces vs Inheritance (or, watch out for Go!)". artima. Retrieved 15 November 2009.
  36. ^ Astels, Dave (9 November 2009). "Ready, Set, Go!". engineyard. Retrieved 9 November 2009.
  37. ^ Paul, Ryan (10 November 2009). "Go: new open source programming language from Google". Ars Technica. Retrieved 13 November 2009.
  38. ^ "Google's Go Wins Programming Language Of The Year Award". jaxenter. Retrieved 5 December 2012. {{cite web}}: |first= missing |last= (help)
  39. ^ "TIOBE Programming Community Index for August 2013". TIOBE Software. August 2013. Retrieved 16 August 2013.
  40. ^ "Organizations Using Go".
  41. ^ Bruce Eckel (27). "Calling Go from Python via JSON-RPC". Retrieved 29 August 2011. {{cite web}}: Check date values in: |date= and |year= / |date= mismatch (help); Unknown parameter |month= ignored (help)
  42. ^ "FAQ - The Go Programming Language". Golang.org. Retrieved 25 June 2013.
  43. ^ Claburn, Thomas (11 November 2009). "Google 'Go' Name Brings Accusations Of Evil'". InformationWeek. Retrieved 18 January 2010.
  44. ^ "Issue 9 - go - I have already used the name for *MY* programming language". Google Code. Google Inc. Retrieved 12 October 2010.

Template:Z148