The Go programming language is an open source project to make programmers more productive.
Go is expressive, concise, clean, and efficient. Its concurrency mechanisms make it easy to write programs that get the most out of multicore and networked machines, while its novel type system enables flexible and modular program construction. Go compiles quickly to machine code yet has the convenience of garbage collection and the power of run-time reflection. It's a fast, statically typed, compiled language that feels like a dynamically typed, interpreted language.
Instructions for downloading and installing Go.
A brief Hello, World tutorial to get started. Learn a bit about Go code, tools, packages, and modules.
A tutorial of short topics introducing functions, error handling, arrays, maps, unit testing, and compiling.
An interactive introduction to Go in three sections. The first section covers basic syntax and data structures; the second discusses methods and interfaces; and the third introduces Go's concurrency primitives. Each section concludes with a few exercises so you can practice what you've learned. You can take the tour online or install it locally with:
$ go get www.dc-limo.com/x/tour
This will place the
tour binary in your workspace's
This doc explains how to develop a simple set of Go packages inside a module,
and it shows how to use the
to build and test packages.
A document that summarizes commonly used editor plugins and IDEs with Go support.
A document that gives tips for writing clear, idiomatic Go code. A must read for any new Go programmer. It augments the tour and the language specification, both of which should be read first.
Summarizes tools and methodologies to diagnose problems in Go programs.
Answers to common questions about Go.
A list of tutorials to get started with Go.
A wiki maintained by the Go community.
The documentation for the Go standard library.
The documentation for the Go tools.
The official Go Language specification.
A document that specifies the conditions under which reads of a variable in one goroutine can be guaranteed to observe values produced by writes to the same variable in a different goroutine.
A summary of the changes between Go releases.
The official blog of the Go project, featuring news and in-depth articles by the Go team and guests.
Guided tours of Go programs.
- First-Class Functions in Go
- Generating arbitrary text: a Markov chain algorithm
- Share Memory by Communicating
- Writing Web Applications - building a simple web application.
- JSON-RPC: a tale of interfaces
- Go's Declaration Syntax
- Defer, Panic, and Recover
- Go Concurrency Patterns: Timing out, moving on
- Go Slices: usage and internals
- A GIF decoder: an exercise in Go interfaces
- Error Handling and Go
- Organizing Go code
- JSON and Go - using the json package.
- Gobs of data - the design and use of the gob package.
- The Laws of Reflection - the fundamentals of the reflect package.
- The Go image package - the fundamentals of the image package.
- The Go image/draw package - the fundamentals of the image/draw package.
- Using Go Modules - an introduction to using modules in a simple project.
- Migrating to Go Modules - converting an existing project to use modules.
- Publishing Go Modules - how to make new versions of modules available to others.
- Go Modules: v2 and Beyond - creating and publishing major versions 2 and higher.
- Keeping Your Modules Compatible - how to keep your modules compatible with prior minor/patch versions.
- About the Go command - why we wrote it, what it is, what it's not, and how to use it.
- Debugging Go Code with GDB
- Data Race Detector - a manual for the data race detector.
- A Quick Guide to Go's Assembler - an introduction to the assembler used by Go.
- C? Go? Cgo! - linking against C code with cgo.
- Godoc: documenting Go code - writing good documentation for godoc.
- Profiling Go Programs
- Introducing the Go Race Detector - an introduction to the race detector.
Three things that make Go fast, fun, and productive: interfaces, reflection, and concurrency. Builds a toy web crawler to demonstrate these.
One of Go's key design goals is code adaptability; that it should be easy to take a simple design and build upon it in a clean and natural way. In this talk Andrew Gerrand describes a simple "chat roulette" server that matches pairs of incoming TCP connections, and then use Go's concurrency mechanisms, interfaces, and standard library to extend it with a web interface and other features. While the function of the program changes dramatically, Go's flexibility preserves the original design as it grows.
Concurrency is the key to designing high performance network services. Go's concurrency primitives (goroutines and channels) provide a simple and efficient means of expressing concurrent execution. In this talk we see how tricky concurrency problems can be solved gracefully with simple Go code.
This talk expands on the Go Concurrency Patterns talk to dive deeper into Go's concurrency primitives.