To Go или не to Go

14
To Go или не to Go Иван Зезюля Al Digit http://zoid.cc

Transcript of To Go или не to Go

Page 1: To Go или не to Go

To Go или не to Go

Иван Зезюля Al Digithttp://zoid.cc

Page 2: To Go или не to Go

Немного истории• 2007 – идея о новом языке

• 2008 – прототип внутри Google

• 2009 – первый публичный релиз

• 2012 – 1.0

• 2014, июнь – 1.3

Page 3: To Go или не to Go

Создатели• Ken Thompson – UNIX, regexp

• Rob Pike – UNIX, UTF-8

• Robert Griesemer – V8

• Russ Cox

• Ian Taylor

Page 4: To Go или не to Go

Изначальные цели

• эффективная разработка больших программ

• скорость компиляции

• распределенные системы

• многопоточность, работа с сетью

Page 5: To Go или не to Go

Основные фишки

Page 6: To Go или не to Go

Статическая типизация

x := 1 + 2 // int y := 2.0 * 21.0 // float

var x int = 1 + 2 var y float32 = 2.0 * 21.0

Это эквивалентно:

С автоматическим выводом типов:

Page 7: To Go или не to Go

Компиляция в нативный код

• Никаких JIT’ов и интерпретаторов

• Платформы: x86, x86-64, ARM (Linux)

Page 8: To Go или не to Go

Легковесные потоки (goroutines)

func work(data int) { fmt.Println(“trrr") time.Sleep(100 * time.Millisecond) } !for i := 1; i < 5; i++ { go work(i) }

Page 9: To Go или не to Go

Каналы (channels)func sum(values []int, out chan int) { sum := 0 for _, value := range values { sum += value } out <- sum } !values := []int{7, 2, 8, -9, 4, 0} channel := make(chan int) !go sum(values[:len(values)/2], channel) go sum(values[len(values)/2:], channel) !x, y := <-channel, <-channel

Page 10: To Go или не to Go

Интерфейсы

type Reader interface { Read(p []byte) (n int, err error) }

Любой тип, который реализует такой метод Read — является Reader’ом

Page 11: To Go или не to Go

GC

• Неотключаемый

Page 12: To Go или не to Go

Простота и минимализм

C (K&R) 32C++ (1991) 48

Java (3rd ed.) 50C# 77

C++0x 72+11JavaScript 26+16

Python (2.7) 31Pascal 35Oberon 32

Go 25

Количество ключевых слов:

Page 13: To Go или не to Go

Плюшки• Множественные возвращаемые значения

• go fmt

• import "github.com/go-martini/martini"

• Строгая система типов (нет неявных преобразований)

• Весьма хорошая стандартная библиотека

• Слайсы

Page 14: To Go или не to Go

Кто использует Go• Docker, в т.ч. в составе Yandex.Cocaine

• Dropbox (“major parts of infrastructure”)

• Canonical

• Heroku (Doozer data store)

• BBC World News

• AirBrake (crash reporting)

• SoundCloud

• Google :)