时间:2021-05-22
golang用来序列化的模块有很多,我们来介绍3个。
json
首先登场的是json,这个几乎毋庸置疑。
序列化
package mainimport ( "encoding/json" "fmt")type Girl struct { Name string Age int Gender string Where string Is_married bool}func main() { g := Girl{"satori", 16, "f","东方地灵殿", false} //可以直接使用json.Marshal,但是打印出来不好看,这里加上缩进 ret, err := json.MarshalIndent(g, "", " ") if err != nil { fmt.Println(err) } else { //得到的是字节数组,需要转化成string fmt.Println(string(ret)) }}当然golang的大小写我们知道是具有含义的,如果改成小写, 那么该字段是无法被序列化的。但是这样序列化之后的字段,也是大写,如果我们就想要小写该怎么办呢?
反序列化
package mainimport ( "encoding/json" "fmt")type Girl struct { Name string `json:"name"` Age int `json:"age"` Gender string `json:"gender"` Where string `json:"where"` Is_married bool `json:"is_married"`}func main() { g := Girl{"satori", 16, "f","东方地灵殿", false} ret, err := json.MarshalIndent(g, "", " ") if err != nil { fmt.Println(err) return } //创建一个变量 g2 := Girl{} //传入json字符串,和指针 err = json.Unmarshal(ret, &g2) if err != nil { fmt.Println(err) } fmt.Println(g2) //{satori 16 f 东方地灵殿 false} fmt.Println(g2.Name, g2.Age) // satori 16}gob
标准库gob是golang提供的“私有”的编解码方式,它的效率会比json,xml等更高,特别适合在Go语言程序间传递数据。
序列化
package mainimport ( "bytes" "encoding/gob" "fmt")type Girl struct { Name string Age int `json:"age"` Gender string `json:"gender"` Where string `json:"where"` Is_married bool `json:"is_married"`}func main() { g := Girl{"satori", 16, "f", "东方地灵殿", false} //创建缓存 buf := new(bytes.Buffer) //把指针丢进去 enc := gob.NewEncoder(buf) //调用Encode进行序列化 if err := enc.Encode(g); err != nil { fmt.Println(err) return } else { //序列化的内容会被放进buf里面 fmt.Println(buf.String()) }}发现是乱码,因为这类似python的pickle,是该语言独有的。所以我们不认识没关系,golang认识就行了
反序列化
package mainimport ( "bytes" "encoding/gob" "fmt")type Girl struct { Name string Age int `json:"age"` Gender string `json:"gender"` Where string `json:"where"` Is_married bool `json:"is_married"`}func main() { g := Girl{"satori", 16, "f", "东方地灵殿", false} buf := new(bytes.Buffer) enc := gob.NewEncoder(buf) if err := enc.Encode(g);err != nil { fmt.Println(err) return } var g1 = Girl{} //bytes.NewBuffer和bytes.Buffer类似,只不过可以传入一个初始的byte数组,返回一个指针 dec := gob.NewDecoder(bytes.NewBuffer(buf.Bytes())) //调用Decode方法,传入结构体对象指针,会自动将buf.Bytes()里面的内容转换成结构体 if err := dec.Decode(&g1);err != nil { fmt.Println(err) return } else { fmt.Println(g1) // {satori 16 f 东方地灵殿 false} }}msgpack
MessagePack是一种高效的二进制序列化格式。它允许你在多种语言(如JSON)之间交换数据。但它更快更小。
安装
go get -u github.com/vmihailenco/msgpack序列化和反序列化
接口和json是一致的
package mainimport ( "fmt" "github.com/vmihailenco/msgpack")type Girl struct { Name string Age int `json:"age"` Gender string `json:"gender"` Where string `json:"where"` Is_married bool `json:"is_married"`}func main() { g := Girl{"satori", 16, "f", "东方地灵殿", false} //这个没有MarshalIndent if ret, err := msgpack.Marshal(g); err != nil { fmt.Println(err) return } else { fmt.Println(string(ret)) //��Name�satori�Age� �Gender�f�Where�东方地灵殿�Is_married� var g1 = Girl{} if err := msgpack.Unmarshal(ret, &g1);err!=nil { fmt.Println(err) return } else { fmt.Println(g1) // {satori 16 f 东方地灵殿 false} } }}到此这篇关于golang的序列化与反序列化的几种方式的文章就介绍到这了,更多相关golang 序列化与反序列化内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了C#实现Xml序列化与反序列化的方法。分享给大家供大家参考。具体实现方法如下:复制代码代码如下://////Xml序列化与反序列化///publi
Java—IO流对象的序列化和反序列化序列化的基本操作 1.对象序列化,就是将Object转换成byte序列,反之叫对象的反序列化。 2.序列化流(Obje
1.Java序列化与反序列化Java序列化是指把Java对象转换为字节序列的过程;而Java反序列化是指把字节序列恢复为Java对象的过程。2.为什么需要序列化
序列化与反序列化是.net程序设计中常见的应用,本文即以实例展示了.net实现序列化与反序列化的方法。具体如下:一般来说,.net中的序列化其实就是将一个对象的
1、Java序列化与反序列化是什么?Java序列化是指把Java对象转换为字节序列的过程,而Java反序列化是指把字节序列恢复为Java对象的过程:序列化:对象