在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 教程/ GO/ 12.11 用 Gob 傳輸數(shù)據(jù)
4.7 strings 和 strconv 包
13.6 啟動(dòng)外部命令和程序
?# 11.4 類(lèi)型判斷:type-switch
12.1 讀取用戶(hù)的輸入
10.6 方法
12.2 文件讀寫(xiě)
13 錯(cuò)誤處理與測(cè)試
9.3 鎖和 sync 包
12.3 文件拷貝
?# 11.7 第一個(gè)例子:使用 Sorter 接口排序
?# 11.5 測(cè)試一個(gè)值是否實(shí)現(xiàn)了某個(gè)接口
6.4 defer 和追蹤
12.10 XML 數(shù)據(jù)格式
13.10 性能調(diào)試:分析并優(yōu)化 Go 程序
?# 11.1 接口是什么
2.2 Go 環(huán)境變量
2.6 安裝目錄清單
2.5 在 Windows 上安裝 Go
11.11 Printf 和反射
1.2 語(yǔ)言的主要特性與發(fā)展的環(huán)境和影響因素
9.0 包(package)
7.4 切片重組(reslice)
13.2 運(yùn)行時(shí)異常和 panic
10.2 使用工廠方法創(chuàng)建結(jié)構(gòu)體實(shí)例
12.8 使用接口的實(shí)際例子:fmt.Fprintf
2.4 在 Mac OS X 上安裝 Go
3.8 Go 性能說(shuō)明
7.2 切片
8.0 Map
3.1 Go 開(kāi)發(fā)環(huán)境的基本要求
5.6 標(biāo)簽與 goto
6.10 使用閉包調(diào)試
9.5 自定義包和可見(jiàn)性
4.3 常量
?# 11.2 接口嵌套接口
6.5 內(nèi)置函數(shù)
前言
10.8 垃圾回收和 SetFinalizer
2.8 Go 解釋器
13.7 Go 中的單元測(cè)試和基準(zhǔn)測(cè)試
6.8 閉包
4.9 指針
13.1 錯(cuò)誤處理
10.1 結(jié)構(gòu)體定義
5.1 if-else 結(jié)構(gòu)
6.6 遞歸函數(shù)
9.9 通過(guò) Git 打包和安裝
2.7 Go 運(yùn)行時(shí)(runtime)
10.7 類(lèi)型的 String() 方法和格式化描述符
3.7 其它工具
9.6 為自定義包使用 godoc
11.12 接口與動(dòng)態(tài)類(lèi)型
13.3 從 panic 中恢復(fù)(Recover)
10.3 使用自定義包中的結(jié)構(gòu)體
11.14 結(jié)構(gòu)體、集合和高階函數(shù)
3.6 生成代碼文檔
9.2 regexp 包
4.1 文件名、關(guān)鍵字與標(biāo)識(shí)符
?# 11.6 使用方法集與接口
7.0 數(shù)組與切片
7.1 聲明和初始化
12.11 用 Gob 傳輸數(shù)據(jù)
5.5 Break 與 continue
1.1 起源與發(fā)展
?# 11 接口(Interfaces)與反射(reflection)
6.9 應(yīng)用閉包:將函數(shù)作為返回值
4.2 Go 程序的基本結(jié)構(gòu)和要素
8.6 將 map 的鍵值對(duì)調(diào)
6.11 計(jì)算函數(shù)執(zhí)行時(shí)間
5.0 控制結(jié)構(gòu)
10.5 匿名字段和內(nèi)嵌結(jié)構(gòu)體
4.6 字符串
3.0 編輯器、集成開(kāi)發(fā)環(huán)境與其它工具
13.8 測(cè)試的具體例子
7.6 字符串、數(shù)組和切片的應(yīng)用
8.4 map 類(lèi)型的切片
3.9 與其它語(yǔ)言進(jìn)行交互
7.3 For-range 結(jié)構(gòu)
9.7 使用 go install 安裝自定義包
6.0 函數(shù)
9.8 自定義包的目錄結(jié)構(gòu)、go install 和 go test
6.3 傳遞變長(zhǎng)參數(shù)
13.9 用(測(cè)試數(shù)據(jù))表驅(qū)動(dòng)測(cè)試
11.9 空接口
8.1 聲明、初始化和 make
6.2 函數(shù)參數(shù)與返回值
9.11 在 Go 程序中使用外部庫(kù)
3.3 調(diào)試器
4.5 基本類(lèi)型和運(yùn)算符
?# 11.8 第二個(gè)例子:讀和寫(xiě)
12.5 用 buffer 讀取文件
總結(jié):Go 中的面向?qū)ο?/span>
11.10 反射包
12.7 用 defer 關(guān)閉文件
9.4 精密計(jì)算和 big 包
4.4 變量
6.1 介紹
13.4 自定義包中的錯(cuò)誤處理和 panicking
12.4 從命令行讀取參數(shù)
9.10 Go 的外部包和項(xiàng)目
8.3 for-range 的配套用法
3.5 格式化代碼
10.4 帶標(biāo)簽的結(jié)構(gòu)體
7.5 切片的復(fù)制與追加
?# 11.3 類(lèi)型斷言:如何檢測(cè)和轉(zhuǎn)換接口變量的類(lèi)型
5.4 for 結(jié)構(gòu)
4.8 時(shí)間和日期
2.3 在 Linux 上安裝 Go
12 讀寫(xiě)數(shù)據(jù)
6.12 通過(guò)內(nèi)存緩存來(lái)提升性能
9.1 標(biāo)準(zhǔn)庫(kù)概述
12.6 用切片讀寫(xiě)文件
10 結(jié)構(gòu)(struct)與方法(method)
8.5 map 的排序
12.9 JSON 數(shù)據(jù)格式
13.5 一種用閉包處理錯(cuò)誤的模式
3.2 編輯器和集成開(kāi)發(fā)環(huán)境
12.12 Go 中的密碼學(xué)
5.2 測(cè)試多返回值函數(shù)的錯(cuò)誤
6.7 將函數(shù)作為參數(shù)
8.2 測(cè)試鍵值對(duì)是否存在及刪除元素
3.4 構(gòu)建并運(yùn)行 Go 程序
2.1 平臺(tái)與架構(gòu)
5.3 switch 結(jié)構(gòu)

12.11 用 Gob 傳輸數(shù)據(jù)

Gob 是 Go 自己的以二進(jìn)制形式序列化和反序列化程序數(shù)據(jù)的格式;可以在 encoding 包中找到。這種格式的數(shù)據(jù)簡(jiǎn)稱(chēng)為 Gob (即 Go binary 的縮寫(xiě))。類(lèi)似于 Python 的 "pickle" 和 Java 的 "Serialization"。

Gob 通常用于遠(yuǎn)程方法調(diào)用(RPCs,參見(jiàn) 15.9 的 rpc 包)參數(shù)和結(jié)果的傳輸,以及應(yīng)用程序和機(jī)器之間的數(shù)據(jù)傳輸。 它和 JSON 或 XML 有什么不同呢?Gob 特定地用于純 Go 的環(huán)境中,例如,兩個(gè)用 Go 寫(xiě)的服務(wù)之間的通信。這樣的話(huà)服務(wù)可以被實(shí)現(xiàn)得更加高效和優(yōu)化。 Gob 不是可外部定義,語(yǔ)言無(wú)關(guān)的編碼方式。因此它的首選格式是二進(jìn)制,而不是像 JSON 和 XML 那樣的文本格式。 Gob 并不是一種不同于 Go 的語(yǔ)言,而是在編碼和解碼過(guò)程中用到了 Go 的反射。

Gob 文件或流是完全自描述的:里面包含的所有類(lèi)型都有一個(gè)對(duì)應(yīng)的描述,并且總是可以用 Go 解碼,而不需要了解文件的內(nèi)容。

只有可導(dǎo)出的字段會(huì)被編碼,零值會(huì)被忽略。在解碼結(jié)構(gòu)體的時(shí)候,只有同時(shí)匹配名稱(chēng)和可兼容類(lèi)型的字段才會(huì)被解碼。當(dāng)源數(shù)據(jù)類(lèi)型增加新字段后,Gob 解碼客戶(hù)端仍然可以以這種方式正常工作:解碼客戶(hù)端會(huì)繼續(xù)識(shí)別以前存在的字段。并且還提供了很大的靈活性,比如在發(fā)送者看來(lái),整數(shù)被編碼成沒(méi)有固定長(zhǎng)度的可變長(zhǎng)度,而忽略具體的 Go 類(lèi)型。

假如在發(fā)送者這邊有一個(gè)有結(jié)構(gòu) T:

type T struct { X, Y, Z int }
var t = T{X: 7, Y: 0, Z: 8}

而在接收者這邊可以用一個(gè)結(jié)構(gòu)體 U 類(lèi)型的變量 u 來(lái)接收這個(gè)值:

type U struct { X, Y *int8 }
var u U

在接收者中,X 的值是7,Y 的值是0(Y的值并沒(méi)有從 t 中傳遞過(guò)來(lái),因?yàn)樗橇阒担?/p>

和 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。

我們把示例 12.12 的信息寫(xiě)進(jìn)名為 vcard.gob 的文件作為例子。這會(huì)產(chǎn)生一個(gè)文本可讀數(shù)據(jù)和二進(jìn)制數(shù)據(jù)的混合,當(dāng)你試著在文本編輯中打開(kāi)的時(shí)候會(huì)看到。

在示例 12.18 中你會(huì)看到一個(gè)編解碼,并且以字節(jié)緩沖模擬網(wǎng)絡(luò)傳輸?shù)暮?jiǎn)單例子:

示例 12.18 gob1.go

// gob1.go
package main

import (
    "bytes"
    "fmt"
    "encoding/gob"
    "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)
}
// Output:   "Pythagoras": {3,4}

示例 12.19 gob2.go 編碼到文件:

// gob2.go
package main

import (
    "encoding/gob"
    "log"
    "os"
)

type Address struct {
    Type             string
    City             string
    Country          string
}

type VCard struct {
    FirstName   string
    LastName    string
    Addresses   []*Address
    Remark      string
}

var content string

func main() {
    pa := &Address{"private", "Aartselaar","Belgium"}
    wa := &Address{"work", "Boom", "Belgium"}
    vc := VCard{"Jan", "Kersschot", []*Address{pa,wa}, "none"}
    // fmt.Printf("%v: \n", vc) // {Jan Kersschot [0x126d2b80 0x126d2be0] none}:
    // using an encoder:
    file, _ := os.OpenFile("vcard.gob", os.O_CREATE|os.O_WRONLY, 0666)
    defer file.Close()
    enc := gob.NewEncoder(file)
    err := enc.Encode(vc)
    if err != nil {
        log.Println("Error in encoding gob")
    }
}

練習(xí) 12.8degob.go

寫(xiě)一個(gè)程序讀取 vcard.gob 文件,解碼并打印它的內(nèi)容。

鏈接

上一篇:3.6 生成代碼文檔下一篇:6.8 閉包