Skip to content

Latest commit

 

History

History
51 lines (43 loc) · 3.26 KB

File metadata and controls

51 lines (43 loc) · 3.26 KB

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)
}