Go語(yǔ)言使用Gob傳輸數(shù)據(jù)
為了讓某個(gè)數(shù)據(jù)結(jié)構(gòu)能夠在網(wǎng)絡(luò)上傳輸或能夠保存至文件,它必須被編碼然后再解碼。當(dāng)然已經(jīng)有許多可用的編碼方式了,比如 JSON、XML、Google 的 protocol buffers 等等。而現(xiàn)在又多了一種,由Go語(yǔ)言 encoding/gob 包提供的方式。
Gob 是Go語(yǔ)言自己以二進(jìn)制形式序列化和反序列化程序數(shù)據(jù)的格式,可以在 encoding 包中找到。這種格式的數(shù)據(jù)簡(jiǎn)稱(chēng)為 Gob(即 Go binary 的縮寫(xiě))。類(lèi)似于 Python 的“pickle”和 Java 的“Serialization”。
Gob 和 JSON 的 pack 之類(lèi)的方法一樣,由發(fā)送端使用 Encoder 對(duì)數(shù)據(jù)結(jié)構(gòu)進(jìn)行編碼。在接收端收到消息之后,接收端使用 Decoder 將序列化的數(shù)據(jù)變化成本地變量。
Go語(yǔ)言可以通過(guò) JSON 或 Gob 來(lái)序列化 struct 對(duì)象,雖然 JSON 的序列化更為通用,但利用 Gob 編碼可以實(shí)現(xiàn) JSON 所不能支持的 struct 的方法序列化,利用 Gob 包序列化 struct 保存到本地也十分簡(jiǎn)單。
Gob 不是可外部定義、語(yǔ)言無(wú)關(guān)的編碼方式,它的首選的是二進(jìn)制格式,而不是像 JSON 或 XML 那樣的文本格式。Gob 并不是一種不同于 Go 的語(yǔ)言,而是在編碼和解碼過(guò)程中用到了 Go 的反射。
Gob 通常用于遠(yuǎn)程方法調(diào)用參數(shù)和結(jié)果的傳輸,以及應(yīng)用程序和機(jī)器之間的數(shù)據(jù)傳輸。它和 JSON 或 XML 有什么不同呢?Gob 特定的用于純 Go 的環(huán)境中,例如兩個(gè)用Go語(yǔ)言寫(xiě)的服務(wù)之間的通信。這樣的話服務(wù)可以被實(shí)現(xiàn)得更加高效和優(yōu)化。
Gob 文件或流是完全自描述的,它里面包含的所有類(lèi)型都有一個(gè)對(duì)應(yīng)的描述,并且都是可以用Go語(yǔ)言解碼,而不需要了解文件的內(nèi)容。
只有可導(dǎo)出的字段會(huì)被編碼,零值會(huì)被忽略。在解碼結(jié)構(gòu)體的時(shí)候,只有同時(shí)匹配名稱(chēng)和可兼容類(lèi)型的字段才會(huì)被解碼。當(dāng)源數(shù)據(jù)類(lèi)型增加新字段后,Gob 解碼客戶端仍然可以以這種方式正常工作。解碼客戶端會(huì)繼續(xù)識(shí)別以前存在的字段,并且還提供了很大的靈活性,比如在發(fā)送者看來(lái),整數(shù)被編碼成沒(méi)有固定長(zhǎng)度的可變長(zhǎng)度,而忽略具體的 Go 類(lèi)型。
假如有下面這樣一個(gè)結(jié)構(gòu)體 T:
type T struct { X, Y, Z int } var t = T{X: 7, Y: 0, Z: 8}
而在接收時(shí)可以用一個(gè)結(jié)構(gòu)體 U 類(lèi)型的變量 u 來(lái)接收這個(gè)值:
type U struct { X, Y *int8 } var u U
在接收時(shí),X 的值是 7,Y 的值是 0(Y 的值并沒(méi)有從 t 中傳遞過(guò)來(lái),因?yàn)樗橇阒担┖?JSON 的使用方式一樣,Gob 使用通用的 io.Writer 接口,通過(guò) NewEncoder() 函數(shù)創(chuàng)建 Encoder 對(duì)象并調(diào)用 Encode(),相反的過(guò)程使用通用的 io.Reader 接口,通過(guò) NewDecoder() 函數(shù)創(chuàng)建 Decoder 對(duì)象并調(diào)用 Decode 。
創(chuàng)建 gob 文件
下面通過(guò)簡(jiǎn)單的示例程序來(lái)演示Go語(yǔ)言是如何創(chuàng)建 gob 文件的,代碼如下所示:
package main import ( "encoding/gob" "fmt" "os" ) func main() { info := map[string]string{ "name": "腳本之家", "website": "http://jb51.net/golang/", } name := "demo.gob" File, _ := os.OpenFile(name, os.O_RDWR|os.O_CREATE, 0777) defer File.Close() enc := gob.NewEncoder(File) if err := enc.Encode(info); err != nil { fmt.Println(err) } }
運(yùn)行上面的代碼會(huì)在當(dāng)前目錄下生成 demo.gob 文件,文件的內(nèi)容如下所示:
0eff 8104 0102 ff82 0001 0c01 0c00 0041
ff82 0002 046e 616d 6510 43e8 afad e8a8
80e4 b8ad e696 87e7 bd91 0777 6562 7369
7465 1e68 7474 703a 2f2f 632e 6269 616e
... ...
讀取 gob 文件
讀取 gob 文件與創(chuàng)建 gob 文件同樣簡(jiǎn)單,示例代碼如下:
package main import ( "encoding/gob" "fmt" "os" ) func main() { var M map[string]string File, _ := os.Open("demo.gob") D := gob.NewDecoder(File) D.Decode(&M) fmt.Println(M) }
運(yùn)行結(jié)果如下:
go run main.go
map[name:腳本之家 website:http://jb51.net/golang/]
到此這篇關(guān)于Go語(yǔ)言使用Gob傳輸數(shù)據(jù)的文章就介紹到這了,更多相關(guān)Go語(yǔ)言 Gob傳輸數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
golang復(fù)制文件夾移動(dòng)到另一個(gè)文件夾實(shí)現(xiàn)方法詳解
這篇文章主要為大家介紹了golang復(fù)制文件夾并移動(dòng)到另一個(gè)文件夾實(shí)現(xiàn)方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07gin通過(guò)go build -tags實(shí)現(xiàn)json包切換及庫(kù)分析
這篇文章主要為大家介紹了gin通過(guò)go build -tags實(shí)現(xiàn)json包切換及庫(kù)分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09GoFrame框架gcache的緩存控制淘汰策略實(shí)踐示例
這篇文章主要為大家介紹了GoFrame框架gcache的緩存控制淘汰策略的實(shí)踐示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06Go語(yǔ)言單元測(cè)試的實(shí)現(xiàn)及用例
在日常開(kāi)發(fā)中,我們通常需要針對(duì)現(xiàn)有的功能進(jìn)行單元測(cè)試,以驗(yàn)證開(kāi)發(fā)的正確性,本文主要介紹了Go語(yǔ)言單元測(cè)試的實(shí)現(xiàn)及用例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01基于Golang實(shí)現(xiàn)延遲隊(duì)列(DelayQueue)
延遲隊(duì)列是一種特殊的隊(duì)列,元素入隊(duì)時(shí)需要指定到期時(shí)間(或延遲時(shí)間),從隊(duì)頭出隊(duì)的元素必須是已經(jīng)到期的。本文將用Golang實(shí)現(xiàn)延遲隊(duì)列,感興趣的可以了解下2022-09-09go語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易比特幣系統(tǒng)錢(qián)包的原理解析
這篇文章主要介紹了go語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易比特幣系統(tǒng)錢(qián)包的原理解析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04golang將切片或數(shù)組根據(jù)某個(gè)字段進(jìn)行分組操作
這篇文章主要介紹了golang將切片或數(shù)組根據(jù)某個(gè)字段進(jìn)行分組操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12