Gob - это пакет в Go, предназначенный для передачи данных между машинами. Он используется для кодирования и декодирования данных в бинарный формат. Вот некоторые особенности и преимущества gob:
- Простота использования: Благодаря отражению в Go, нет необходимости в отдельном языке определения интерфейса или "компиляторе протокола". Структура данных сама по себе - все, что пакету нужно знать, чтобы определить, как ее кодировать и декодировать.
- Эффективность: Текстовые представления, такие как XML и JSON, слишком медленные для эффективной сети связи. Необходимо бинарное кодирование.
- Самоописываемые потоки: Каждый поток gob, прочитанный с начала, содержит достаточно информации, чтобы весь поток мог быть проанализирован агентом, который ничего не знает о его содержимом.
Gob был разработан с учетом опыта работы с протокольными буферами Google, но избегает некоторых их особенностей. Например, протокольные буферы работают только с типом данных, который мы называем структурой в Go. Вы не можете кодировать целое число или массив на верхнем уровне, только структуру с полями внутри. Это кажется бессмысленным ограничением, по крайней мере, в Go.
Таким образом, gob предоставляет эффективный и удобный способ сериализации и десериализации структур данных в Go, особенно при работе в среде, специфической для Go, такой как общение между двумя серверами, написанными на Go.
package main
import (
"bytes"
"encoding/gob"
"fmt"
"log"
)
type P struct {
X, Y, Z int
Name string
}
type Q struct {
X, Y *int32
Name string
}
func main() {
// Initialize the encoder and decoder. Normally enc and dec would be
// bound to network connections and the encoder and decoder would
// run in different processes.
var network bytes.Buffer // Stand-in for a network connection
enc := gob.NewEncoder(&network) // Will write to network.
dec := gob.NewDecoder(&network) // Will read from network.
// Encode (send) the value.
err := enc.Encode(P{3, 4, 5, "Pythagoras"})
if err != nil {
log.Fatal("encode error:", err)
}
// Decode (receive) the value.
var q Q
err = dec.Decode(&q)
if err != nil {
log.Fatal("decode error:", err)
}
fmt.Printf("%q: {%d,%d}\n", q.Name, *q.X, *q.Y)
}