主頁(yè) > 知識(shí)庫(kù) > golang的序列化與反序列化的幾種方式

golang的序列化與反序列化的幾種方式

熱門標(biāo)簽:谷歌美發(fā)店地圖標(biāo)注 江蘇呼叫中心外呼系統(tǒng)有效果嗎 赤峰電銷 地圖區(qū)域圖標(biāo)注后導(dǎo)出 貴州電話智能外呼系統(tǒng) 官渡電銷外呼管理系統(tǒng)怎么收費(fèi) 杭州人工智能電銷機(jī)器人費(fèi)用 利用地圖標(biāo)注位置 400開(kāi)頭電話怎樣申請(qǐng)

golang用來(lái)序列化的模塊有很多,我們來(lái)介紹3個(gè)。

json

首先登場(chǎng)的是json,這個(gè)幾乎毋庸置疑。

序列化

package main

import (
 "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,但是打印出來(lái)不好看,這里加上縮進(jìn)
 ret, err := json.MarshalIndent(g, "", " ")
 if err != nil {
 fmt.Println(err)
 } else {
 //得到的是字節(jié)數(shù)組,需要轉(zhuǎn)化成string
 fmt.Println(string(ret))
 /*
 {
  "Name": "satori",
  "Age": 16,
  "Gender": "f",
  "Where": "東方地靈殿",
  "Is_married": false
 }
 */
 }
}

當(dāng)然golang的大小寫我們知道是具有含義的,如果改成小寫, 那么該字段是無(wú)法被序列化的。但是這樣序列化之后的字段,也是大寫,如果我們就想要小寫該怎么辦呢?

package main

import (
 "encoding/json"
 "fmt"
)

type Girl struct {
 //使用`json:"xxx"`相當(dāng)于起了一個(gè)別名xxx,以后序列化出來(lái)的字段就叫這個(gè)名字,
 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)
 } else {
 fmt.Println(string(ret))
 /*
 {
  "name": "satori",
  "age": 16,
  "gender": "f",
  "where": "東方地靈殿",
  "is_married": false
 }
 */
 }
}

反序列化

package main

import (
 "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
 }

 //創(chuàng)建一個(gè)變量
 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

標(biāo)準(zhǔn)庫(kù)gob是golang提供的“私有”的編解碼方式,它的效率會(huì)比json,xml等更高,特別適合在Go語(yǔ)言程序間傳遞數(shù)據(jù)。

序列化

package main

import (
 "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}

 //創(chuàng)建緩存
 buf := new(bytes.Buffer)
 //把指針丟進(jìn)去
 enc := gob.NewEncoder(buf)

 //調(diào)用Encode進(jìn)行序列化
 if err := enc.Encode(g); err != nil {
 fmt.Println(err)
 return
 } else {
 //序列化的內(nèi)容會(huì)被放進(jìn)buf里面
 fmt.Println(buf.String())
 /*
 G��Girl�� Name Age Gender Where 
 Is_married  !��satori f東方地靈殿
 */
 }
}

發(fā)現(xiàn)是亂碼,因?yàn)檫@類似python的pickle,是該語(yǔ)言獨(dú)有的。所以我們不認(rèn)識(shí)沒(méi)關(guān)系,golang認(rèn)識(shí)就行了

反序列化

package main

import (
 "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類似,只不過(guò)可以傳入一個(gè)初始的byte數(shù)組,返回一個(gè)指針
 dec := gob.NewDecoder(bytes.NewBuffer(buf.Bytes()))
 //調(diào)用Decode方法,傳入結(jié)構(gòu)體對(duì)象指針,會(huì)自動(dòng)將buf.Bytes()里面的內(nèi)容轉(zhuǎn)換成結(jié)構(gòu)體
 if err := dec.Decode(g1);err != nil {
 fmt.Println(err)
 return
 } else {
 fmt.Println(g1) // {satori 16 f 東方地靈殿 false}
 }
}

msgpack

MessagePack是一種高效的二進(jìn)制序列化格式。它允許你在多種語(yǔ)言(如JSON)之間交換數(shù)據(jù)。但它更快更小。

安裝

go get -u github.com/vmihailenco/msgpack

序列化和反序列化

接口和json是一致的

package main

import (
 "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}

 //這個(gè)沒(méi)有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}
 }
 }
}

到此這篇關(guān)于golang的序列化與反序列化的幾種方式的文章就介紹到這了,更多相關(guān)golang 序列化與反序列化內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • golang中的net/rpc包使用概述(小結(jié))
  • go語(yǔ)言net包rpc遠(yuǎn)程調(diào)用的使用示例
  • Golang Gob編碼(gob包的使用詳解)

標(biāo)簽:鷹潭 宜春 黔西 松原 武漢 河池 泰安 保定

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《golang的序列化與反序列化的幾種方式》,本文關(guān)鍵詞  golang,的,序列化,與,反,幾種,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《golang的序列化與反序列化的幾種方式》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于golang的序列化與反序列化的幾種方式的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章