gob(Go binary)是Goland包自带的一个数据结构序列化的编码/解码工具。编码使用Encoder,解码使用Decoder。一种典型的应用场景就是RPC(remote procedure calls)。

gob和json的pack之类的方法一样,由发送端使用encoder对数据结构进行编码。在接收端使用decoder将序列化的数据转成本地变量。

Go语言可以通过JSON或Gob来序列化struct对象,虽然JSON的序列化更为通用,但利用Gob编码可以实现JSON所不能支持的struct的方法序列化,利用Gob包序列化struct保存到本地也十分简单。

Gob编解码规则

对于Gob而言,发送方和接收方的数据结构并不需要完全一致,官方示例为例:



上述struct{A,B int}结构编码的数据可以被后面九种结构类型接受解码,具体来说,接受数据结构只要满足与发送数据结构签名一致(与顺序无关,类型之间不能相互编解码,整型还要细分有符号和无符号)、或者是发送数据类型的子集(但不能为空)或超集,即正常接收并解码

具体到不同的数据类型,规则如下:

  • struct{A,B int}arrayslice是可以被编码的,但是functionchannel是不能被编码的
  • 整型分为有符号和无符号,无符号和有符号整型是不能互相编解码的
  • 布尔类型是被当做uint来编码的,0false1true
  • 浮点型的值都是被当做float64类型的值来编码的,浮点型和整型也是不能相互编码的
  • 字符串类型(包括string[]byte)是无符号字节个数+每个字节编码的形式编解码的
  • 数组类型(包括slicearray)是按照无符号元素个数+每个数组元素编码的形式进行编解码的
  • 字典类型(map)是按照无符号元素个数+键值对的形式进行编解码的
  • 结构体类型(struct)是按照序列化的属性名+属性值来进行编解码的,其中属性值是其自己对应类型的Gob编码,如果有一个属性值为0或空,则这个属性直接被忽略,每个属性的序号是编码时的顺序决定的,从0开始顺序递增。struct在序列化前会以-1代表序列化的开始,以0代表序列化的结束,即struct的序列化是按照"-1(0属性1的名字 属性1的值)(1 属性2的名字 属性2的值)"来进行编码的

    注:struct类型的属性名都应该是大写字母开头,以便可以在包外被访问

gob包提供的API

结构体

type GobDecoder interface
type GobEncoder interface
type Decoder struct
type Encoder struct

函数列表:

func Register(value interface{})
func RegisterName(name string, value interface{})
func NewDecoder(r io.Reader) *Decoder
func (dec *Decoder) Decode(e interface{}) error
func (dec *Decoder) DecoderValue(v reflect.Value) error
func NewEncoder(w io.Writer) *Encoder
func (enc *Encoder) Encode(e interface{}) error
func (enc *Encoder) EncodeValue(value reflect.Value) error

详解:

1)GobDecoder

type GobDecoder interface {

GobEecode([]byte) error

}

GobDecoder是一个描述数据的结构,提供自己的方案来解码GobE内从der发送的数据

2)GobEncoder

type GobEncoder interface {

GobEncode() ([]byte, error)

}

GobEncoder是一个描述数据的接口,提供自己的方案来将数据编码提供GobDecoder接受并编码。一个实现了GobEnoder接口和GobDecoder接口的类型可以完全控制自身数据的表示,因此可以包含非导出子段、通道、函数等数据,这些数据gob流正常使用不能传输的

// A Decoder manages the receipt of type and data information read from the
// remote side of a connection.
type Decoder struct {
mutex sync.Mutex // each item must be received atomically
r io.Reader // source of the data
buf bytes.Buffer // buffer for more efficient i/o from r
wireType map[typeId]*wireType // map from remote ID to local description
decoderCache map[reflect.Type]map[typeId]**decEngine // cache of compiled engines
ignorerCache map[typeId]**decEngine // ditto for ignored objects
freeList *decoderState // list of free decoderStates; avoids reallocation
countBuf []byte // used for decoding integers while parsing messages
tmp []byte // temporary storage for i/o; saves reallocating
err error
} // An Encoder manages the transmission of type and data information to the
// other side of a connection.
type Encoder struct {
mutex sync.Mutex // each item must be sent atomically
w []io.Writer // where to send the data
sent map[reflect.Type]typeId // which types we've already sent
countState *encoderState // stage for writing counts
freeList *encoderState // list of free encoderStates; avoids reallocation
byteBuf bytes.Buffer // buffer for top-level encoderState
err error
}

1)func Register(value interface{})

Register记录value下层具体值得类型和其名称。该名称将用来识别发送或接收接口类型值下层的具体类型。本函数只应在初始化调用,如果类型和名字的映射不是一一对应的,会panic。

2)func RegisterName(name string, value interface{})

RegisterName,使用自定义的名称替代类型的默认名称。

3)func NewDecoder(r io.Reader) *Decoder

参数列表:r Reader对象

返回值:*Decoder 指向Decoder的指针

功能说明:这个函数主要是给r创建一个decoder实例

4)func (des *Decoder) Decode(e interface{}) error

参数列表:e 空接口类型,可以处理任何类型的数据

返回值:error

功能说明:此函数是Decoder的方法即(method),需要使用NewDcoder()创建*Decoder对象后,才可以使用

5)func (dec *Decoder) DecodeValue(v refletc.Value) error

6)func NewEncoder(w io.Writer) *Encoder

7)func (enc *Encoder) Encode(e interface{}) error

参数列表:v 序列化gob对象

返回值:error错误

功能说明:这个函数主要是讲encode编码的gob数据写入到相关联的对象

8)func (enc *Encoder) EncodeValue(value reflect.Value) error

demo1:自定义gob规则

1)实现GobDecoder、GobEncoder这两个接口

2)编写代码

一篇讲解重新gob的博客,链接

demo2:创建一个编码器,传输一些值,用解码器接收它们。

示例:

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() {
// 初始化编码器和解码器。 通常是enc和dec
// 绑定到网络连接和编码器和解码器会
// 在不同的进程中运行。
var network bytes.Buffer // 替代网络连接
enc := gob.NewEncoder(&network) // 将写入网络。
dec := gob.NewDecoder(&network) // 将从网络上读取。
// Encoding(发送)一些值。
err := enc.Encode(P{3, 4, 5, "Pythagoras"})
if err != nil {
log.Fatal("encode error:", err)
}
err = enc.Encode(P{1782, 1841, 1922, "Treehouse"})
if err != nil {
log.Fatal("encode error:", err)
} // Decode(接收)并打印值。
var q Q
err = dec.Decode(&q)
if err != nil {
log.Fatal("decode error 1:", err)
}
fmt.Printf("%q: {%d, %d}\n", q.Name, *q.X, *q.Y)
err = dec.Decode(&q)
if err != nil {
log.Fatal("decode error 2:", err)
}
fmt.Printf("%q: {%d, %d}\n", q.Name, *q.X, *q.Y) }

参考:https://cloud.tencent.com/developer/section/1141539

https://developer.aliyun.com/article/676396

Go Gob编码的更多相关文章

  1. [转]Golang Gob编码

    Golang Gob编码 2012-08-24 09:47 by 轩脉刃, 5119 阅读, 1 评论, 收藏, 编辑 gob是Golang包自带的一个数据结构序列化的编码/解码工具.编码使用Enco ...

  2. golang - gob与rpc

    今天和大家聊聊golang中怎么使用rpc,rpc数据传输会涉及到gob编码,所以先讲讲gob,别担心,就算你完全没有接触过gob与rpc,只要知道rpc的中文是远程过程调用,剩下的我都能给你讲明白( ...

  3. 转: gob编解码

    要让数据对象能在网络上传输或存储,我们需要进行编码和解码.现在比较流行的编码方式有JSON,XML等.然而,Go在gob包中为我们提供了另一种方式,该方式编解码效率高于JSON.gob是Golang包 ...

  4. go语言time包的学习(Time,Location,Duration,Timer,Ticker)

    package main;   import (     "time"     "fmt" )   func main() {     //time.Time代 ...

  5. Go Revel - Cache(缓存)

    revel在服务器端提供了`cache`库用以低延迟的存储临时数据.它缓存那些需要经常访问数据库但是变化不频繁的数据,也可以实现用户会话的存储. ##有效期 一下三种方法为缓存元素设置过期时间: 1. ...

  6. go语言net包rpc远程调用的使用

    一.基于http的RPC 服务端: package main; import ( "net/rpc" "net/http" "log" ) ...

  7. Go语言_RPC_Go语言的RPC

    一 标准库的RPC RPC(Remote Procedure Call,远程过程调用)是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络细节的应用程序通信协议.简单的说就是要像调用本地函数 ...

  8. 12. Go 语言文件处理

    Go 语言文件处理 本章我们将带领大家深入了解一下 Go语言中的文件处理,重点在于文件而非目录或者通用的文件系统,特别是如何读写标准格式(如 XML 和 JSON 格式)的文件以及自定义的纯文本和二进 ...

  9. sync包 — 汇总

    sync包 package main; import ( "time" "fmt" ) func main() { //time.Time代表一个纳秒精度的时间 ...

  10. time包 — 汇总

    time包学习 package main; import ( "time" "fmt" ) func main() { //time.Time代表一个纳秒精度的 ...

随机推荐

  1. 关于 False、True、0、1、tinyint(1) 的说明

    MySQL 保存 Boolean 值时,用 1 代表 TRUE,0 代表 FALSE:类似一个 bit 位,默认没有数据,即为 0,也即 Faslse MySQL 存储 Boolean 值的类型为 t ...

  2. SpringBoot项目war、jar自定义配置application文件的位置

    此篇文章的真正目的应该是关于war包运行在独立tomcat下时,应如何在war包外部配置application.properties,以达到每次更新war包而不用更新配置文件的目的.百度搜素Sprin ...

  3. 探秘Transformer之(8)--- 位置编码

    探秘Transformer之(8)--- 位置编码 0x00 概述 位置编码(Positional Embedding)是一种用于处理序列数据的技术,被用来表示输入序列中的单词位置.在Transfor ...

  4. 在 Intel Ultra AI PC 设备上使用 OpenVINO™ C# API本地部署YOLOv11与YOLOv12

    ​ 最新的英特尔 酷睿 Ultra 处理器(第二代)让我们能够在台式机.移动设备和边缘中实现大多数 AI 体验,将 AI 加速提升到新水平,在 AI 时代为边缘计算提供动力.英特尔 酷睿 Ultra ...

  5. 【Verilog】表达式位宽与符号判断机制

    缘起于p1课下alu算数位移设计.查了好多资料,最后发现还是主要在翻译官方文档.浪费了超多时间啊,感觉还是没搞透,还是先以应用为导向放一放,且用且归纳 1.表达式位宽 expression bit l ...

  6. Web前端入门第 14 问:HTML 语义化是什么?

    HELLO,这里是大熊学习前端开发的入门笔记. 本系列笔记基于 windows 系统. 语义化:通俗地说,就是让机器可以理解编写出来的 HTML 代码.比如:搜索引擎.屏幕阅读器等. 非语义化写法 网 ...

  7. SpringBoot + 布隆过滤器:亿级数据下的高效防护盾与缓存穿透实战指南

    在当今高并发.海量数据的应用场景中,布隆过滤器凭借其极低的内存占用和极快的查询效率,成为解决缓存穿透.数据预判等难题的利器.本文深度解析布隆过滤器的核心原理与实战应用,手把手教你如何将这一数据守门员融 ...

  8. HashMap 在高并发场景下可能出现的性能问题以及如何规避这些问题

    JDK1.8 之前 HashMap 底层是 数组和链表, 之后在之前基础上加上红黑树. 相比于之前的版本, JDK1.8 之后在解决哈希冲突时有了较大的变化,当链表长度大于阈值(默认为 8)(将链表转 ...

  9. BUUCTF---密码学的心声

    题目 打开题目获取一个BMP的格式图片,根据歌词尝试转换成ASCII码 转ASCII码 将曲谱上面转化,发现是8进制从而转为ASCII码 点击查看代码 nums = [111, 114, 157, 1 ...

  10. EntityFramework 6 分页模式

    在我的另一篇博客中提到了EntityFrameworkCore 分页问题, 中提到了EntityFrameworkCore在针对不同版本SQL Server数据库时如何指定分页模式,那么如何在Enti ...