Jump to content

Go (programming language): Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Interface system: cutting these java/c# references: if you know j/c# interfaces, you'll recognize the similarities/diffs, and if you don't, the comparisons won't help. for now, think the other two comparisons are tolerable
Line 71: Line 71:
Besides calling methods via interfaces, Go also allows converting interface values to other types, with a run-time type check. The language constructs to do so are the ''type assertion''<ref>[http://golang.org/ref/spec#Type_assertions Type Assertions - The Go Language Specification]</ref> or, for checking against multiple types/interfaces, the ''type switch''<ref>[http://golang.org/ref/spec#Type_switches Type switches - The Go Language Specification]</ref>. Interface values act as pointers in many ways, and, like pointers, are <code>nil</code> if uninitialized.<ref>[http://golang.org/ref/spec#Interface_types Interface tyoes - The Go Programming Language Specification]</ref>
Besides calling methods via interfaces, Go also allows converting interface values to other types, with a run-time type check. The language constructs to do so are the ''type assertion''<ref>[http://golang.org/ref/spec#Type_assertions Type Assertions - The Go Language Specification]</ref> or, for checking against multiple types/interfaces, the ''type switch''<ref>[http://golang.org/ref/spec#Type_switches Type switches - The Go Language Specification]</ref>. Interface values act as pointers in many ways, and, like pointers, are <code>nil</code> if uninitialized.<ref>[http://golang.org/ref/spec#Interface_types Interface tyoes - The Go Programming Language Specification]</ref>


<code>interface{}</code>, the ''empty interface'', is an important corner case because it can refer to an item of ''any'' concrete type. Code using the empty interface cannot call methods (or built-in operators) on a referred-to object directly, but it can store it, check if it satisfies a more specific interface (or it it's of a specific known type), or inspect it with Go's <code>reflect</code> package<ref>[http://golang.org/pkg/reflect/#ValueOf reflect.ValueOf(i interface{})] converts an <code>interface{}</code> to a <code>reflect.Value</code> that can be further inspected</ref>. Because it can take any value, <code>interface{}</code> is a limited way to evade the strictures of the typing system when useful, like <code>void*</code> in C or <code>Object</code>/<code>object</code> in Java/C#.
<code>interface{}</code>, the ''empty interface'', is an important corner case because it can refer to an item of ''any'' concrete type. Code using the empty interface cannot call methods (or built-in operators) on a referred-to object directly, but it can store it, check if it satisfies a more specific interface (or if it's of a specific type), or inspect it with Go's <code>reflect</code> package<ref>[http://golang.org/pkg/reflect/#ValueOf reflect.ValueOf(i interface{})] converts an <code>interface{}</code> to a <code>reflect.Value</code> that can be further inspected</ref>. Because it can take any value, <code>interface{}</code> is a limited way to evade the strictures of the typing system when useful, like <code>void*</code> in C or <code>Object</code>/<code>object</code> in Java/C#.


Go has no interface inheritance, but one interface type can ''embed'' another; then the embedding interface requires all of the methods required by the embedded interface.<ref name="memmodel">{{cite web| url = http://golang.org/doc/effective_go.html#interfaces_and_types | title = Effective Go - Interfaces and methods & Embedding | publisher = Google | accessdate =28 November 2011}}</ref>
Go has no interface inheritance, but one interface type can ''embed'' another; then the embedding interface requires all of the methods required by the embedded interface.<ref name="memmodel">{{cite web| url = http://golang.org/doc/effective_go.html#interfaces_and_types | title = Effective Go - Interfaces and methods & Embedding | publisher = Google | accessdate =28 November 2011}}</ref>


In Go, objects don't contain an object header with type information; only interface values do. So, if an object is never accessed via an interface pointer, the interface system doesn't impose any per-object memory overhead. In that sense, Go structs are stored less like Java objects and more like C structs or C# ValueTypes.<ref>{{cite web|url = http://research.swtch.com/interfaces | title = Go Data Structures: Interfaces | accessdate=15 November 2012}}</ref>
Go's objects don't contain an object header with type information; only interface values do. So, if an object is never accessed via an interface pointer, the interface system doesn't impose any per-object memory overhead. In that sense, Go structs are stored less like Java objects and more like C structs or C# ValueTypes.<ref>{{cite web|url = http://research.swtch.com/interfaces | title = Go Data Structures: Interfaces | accessdate=15 November 2012}}</ref>


==Name visibility==
==Name visibility==

Revision as of 06:07, 6 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, sometimes referred to as golang, is an open source, compiled, garbage-collected, concurrent system programming language. It was first designed and developed at Google Inc.[6] beginning in September 2007 by Robert Griesemer, Rob Pike, and Ken Thompson.[5]

The language was officially announced in November 2009 and is now used in some of Google's production systems.[7] 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.[8]

Goals

Go aims to provide the efficiency of a statically typed compiled language with the ease of programming of a dynamic language.[9] Other goals include:

  • Safety: Type-safe and memory-safe.
  • Intuitive concurrency by providing "goroutines" and channels to communicate between them.
  • Efficient garbage collection "with low enough overhead and no significant latency".[10]
  • High-speed compilation.

Description

The syntax of Go is broadly similar to that of C: blocks of code are surrounded with curly braces; common control flow structures include for, switch, and if. Unlike C, line-ending semicolons are optional, variable declarations are written differently and are usually optional, type conversions must be made explicitly, and new go and select control keywords have been introduced to support concurrent programming. New built-in types include maps, array slices, and channels for inter-thread communication.

Go is designed for exceptionally fast compilation times, even on modest hardware.[11] The language requires garbage collection. Some concurrency-related structural conventions of Go (channels and alternative channel inputs) are borrowed from Tony Hoare's CSP. Unlike previous concurrent programming languages such as occam or Limbo, Go does not provide any built-in notion of safe or verifiable concurrency.[12]

Of features found in C++ or Java, Go does not include type inheritance, generic programming, assertions, method overloading, or pointer arithmetic.[5] With respect to these omissions, 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] Initially, the language did not include exception handling, but in March 2010 a mechanism known as panic/recover was implemented to handle exceptional errors while avoiding some of the problems the Go authors find with exceptions.[13][14]

Interface system

In place of a virtual inheritance system, Go uses only interfaces. An interface declaration lists any methods the concrete type must implement: for example, io.Reader's declaration requires a Read method with a particular signature to satisfy it. Code passed an io.Reader can then call the Read method, without concern for whether the specific source it's reading from is an HTTP connection, a file, an in-memory buffer, or anything else.

Go's standard library defines interfaces wherever it needs to be passed an object of a general type that might have more than one concrete implementation: an input/output stream, a sortable collection, something printable as a string, a cryptographic hash, a binary encoding of numbers, and so on.[15]

Go types don't declare which interfaces they implement: having any necessary methods is implementing the interface. A type can implement a String() function to return a string "dump" of an object. Because it has that method, the type implements the fmt.Stringer interface, and functions like fmt.Println will use the String() method when printing objects of that type. The module where the String method is defined need not even import the fmt module. In the following code, the Sequence type nor the Size method have to declare that the type implemented Sizer:

// in the 'sequence' package
type Sequence []int

func (s Sequence) Size() int {
    return len(s)
}

// in another package
type Sizer interface {
    Size() int
}

func IsNonempty(o Sizer) bool {
    return o.Size() > 0
}

Besides calling methods via interfaces, Go also allows converting interface values to other types, with a run-time type check. The language constructs to do so are the type assertion[16] or, for checking against multiple types/interfaces, the type switch[17]. Interface values act as pointers in many ways, and, like pointers, are nil if uninitialized.[18]

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 cannot call methods (or built-in operators) on a referred-to object directly, but it can store it, check if it satisfies a more specific interface (or if it's of a specific type), or inspect it with Go's reflect package[19]. Because it can take any value, interface{} is a limited way to evade the strictures of the typing system when useful, like void* in C or Object/object in Java/C#.

Go has no interface inheritance, but one interface type can embed another; then the embedding interface requires all of the methods required by the embedded interface.[12]

Go's objects don't contain an object header with type information; only interface values do. So, if an object is never accessed via an interface pointer, the interface system doesn't impose any per-object memory overhead. In that sense, Go structs are stored less like Java objects and more like C structs or C# ValueTypes.[20]

Name visibility

Visibility of structure, structure fields, variables, constants, methods, top-level types and functions outside their defining package is defined implicitly according to the capitalization of their identifier. If the identifier starts with a capital letter, the identifier is visible from outside the package.[21]

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. Race conditions can occur in concurrent Go programs. Concurrent Go programs are not memory safe.[22]

Implementations

There are currently two Go compilers:

  • 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++,[23] and now officially supported as of version 4.6, albeit not part of the standard binary for gcc.[24]

Both compilers work on Unix-like systems, and a port to Microsoft Windows of the gc compiler and runtime have been integrated in the main distribution. Most of the standard libraries also work on Windows.

There is also an unmaintained "tiny" runtime environment that allows Go programs to run on bare hardware.[25]

Examples

Hello world

The following is a Hello world program in Go:

package main

import "fmt"

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

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.[26]

Echo

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

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:[28]

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:[29]

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:[30]

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

Bruce Eckel stated:[34]

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.[35]

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.[36] 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."[37]

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 d "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. ^ "Go FAQ: Is Google using Go internally?". Retrieved 9 March 2013.
  8. ^ "Installing Go". golang.org. The Go Authors. 11 June 2010. Retrieved 11 June 2010.
  9. ^ Pike, Rob. "The Go Programming Language". YouTube. Retrieved 1 July 2011.
  10. ^ "Why do garbage collection? Won't it be too expensive?". Retrieved 12 February 2013.
  11. ^ Rob Pike (10 November 2009). The Go Programming Language (flv) (Tech talk). Google. Event occurs at 8:53.
  12. ^ a b "The Go Memory Model". Google. Retrieved 5 January 2011. Cite error: The named reference "memmodel" was defined multiple times with different content (see the help page).
  13. ^ Release notes, 30 March 2010
  14. ^ "Proposal for an exception-like mechanism". golang-nuts. 25 March 2010. Retrieved 25 March 2010.
  15. ^ Packages - The Go Programming Language, packages io, sort, fmt, hash, and encoding/binary
  16. ^ Type Assertions - The Go Language Specification
  17. ^ Type switches - The Go Language Specification
  18. ^ Interface tyoes - The Go Programming Language Specification
  19. ^ reflect.ValueOf(i interface{}) converts an interface{} to a reflect.Value that can be further inspected
  20. ^ "Go Data Structures: Interfaces". Retrieved 15 November 2012.
  21. ^ "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.
  22. ^ "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."
  23. ^ "FAQ: Implementation". golang.org. 16 January 2010. Retrieved 18 January 2010.
  24. ^ "Installing GCC: Configuration". Retrieved 3 December 2011. Ada, Go and Objective-C++ are not default languages
  25. ^ Gerrand, Andrew (1 February 2011). "release.2011-02-01". golang-nuts. Google. Retrieved 5 February 2011.
  26. ^ "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.
  27. ^ "A Tutorial for the Go Programming Language". golang.org. 16 January 2010. Retrieved 18 January 2010.
  28. ^ Simionato, Michele (15 November 2009). "Interfaces vs Inheritance (or, watch out for Go!)". artima. Retrieved 15 November 2009.
  29. ^ Astels, Dave (9 November 2009). "Ready, Set, Go!". engineyard. Retrieved 9 November 2009.
  30. ^ Paul, Ryan (10 November 2009). "Go: new open source programming language from Google". Ars Technica. Retrieved 13 November 2009.
  31. ^ "Google's Go Wins Programming Language Of The Year Award". jaxenter. Retrieved 5 December 2012. {{cite web}}: |first= missing |last= (help)
  32. ^ "TIOBE Programming Community Index for August 2013". TIOBE Software. August 2013. Retrieved 16 August 2013.
  33. ^ "Organizations Using Go".
  34. ^ 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)
  35. ^ "FAQ - The Go Programming Language". Golang.org. Retrieved 25 June 2013.
  36. ^ Claburn, Thomas (11 November 2009). "Google 'Go' Name Brings Accusations Of Evil'". InformationWeek. Retrieved 18 January 2010.
  37. ^ "Issue 9 - go - I have already used the name for *MY* programming language". Google Code. Google Inc. Retrieved 12 October 2010.

Template:Z148