首頁 > 後端開發 > Golang > 主體

介紹Golang序列化和反序列化

藏色散人
發布: 2020-09-30 13:48:56
轉載
3200 人瀏覽過

以下由golang教學專欄來介紹Golang序列化和反序列化,希望對需要的朋友有幫助!

介紹Golang序列化和反序列化

為什麼要序列化和反序列化

  我們的資料物件要在網路中傳輸或儲存到文件,就需要對其編碼和解碼動作,目前存在許多編碼格式:json, XML, Gob, Google Protocol Buffer 等, Go 語言當然也支援所有這些編碼格式。

序列化與反序列化定義

  序列化 (Serialization)是將物件的狀態資訊轉換為可以儲存或傳輸的形式的過程。在序列化期間,物件將其目前狀態寫入到臨時或持久性儲存區。透過從儲存區讀取物件的狀態,重新建立該對象,則為反序列化

序列化與反序列化規則

Go類型              json 類型

bool                   booleans

float64               numbers#                 null

#在解析json 格式資料時,若以interface{} 接收數據,需依照以上規則進行解析。

程式碼示範

反序列化

package main

import (   "encoding/json"
   "fmt")

type People struct {
   name   string  `json:"name"` // name,小写不导出
   Age    int     `json:"age"`  // age
   Gender string `json:"gender"`  // gender   Lesson
}

type Lesson struct {
   Lessons []string `json:"lessons"`
}

func main() {
   jsonstr := `{"Age": 18,"name": "Jim" ,"gender": "男","lessons":["English","History"],"Room":201,"n":null,"b":false}`   // 反序列化   var people People   if err := json.Unmarshal([]byte(jsonstr),&people); err == nil {      fmt.Println("struct people:")      fmt.Println(people)
   }   // 反序列化 json 字符串中的一部分   var lessons Lesson   if err := json.Unmarshal([]byte(jsonstr),&lessons); err == nil {      fmt.Println("struct lesson:")      fmt.Println(lessons)
   }   // 反序列化 json 字符串数组
   jsonstr = `["English","History"]`
   var str []string
   if err := json.Unmarshal([]byte(jsonstr), &str); err == nil {      fmt.Println("struct str:")      fmt.Println(str)
   }
}// 打印结果  struct people:
  { 18 男 {[English History]}}
  struct lesson:
  {[English History]}
  struct str:
  [English History]
登入後複製

反序列化

#序列化

package main

import (    "encoding/json"
    "fmt")

type People struct {
    name   string  `json:"name"` // name,小写不导出
    Age    int     `json:"age"`  // age,在 json 字符串中叫 age
    Gender string `json:"gender"`  // gender    Lesson
}

type Lesson struct {
    Lessons []string `json:"lessons"`
}

func main() {
    lesson := Lesson{[]string{"Math","English","Chinese"}}
    people := &People{
        name:   "amy",
        Age:    22,
        Gender: "female",
        Lesson: lesson,
    }    if b, err := json.Marshal(people); err != nil {        fmt.Println("Marshal failed...")
    }else {        fmt.Println(b)        fmt.Println(string(b))
    }
}    // 打印结果
    [123 34 97 103 101 34 58 50 50 44 34 103 101 110 100 101 114 34 58 34 102 101 109 97 108 101 34 44 34 108 101 115 115 111 110 115 34 58 91 34 77 97 116 104 34 44 34 69 110 103 108 105 115 104 34 44 34 67 104 105 110 101 115 101 34 93 125]
{"age":22,"gender":"female","lessons["Math","English","Chinese“}
登入後複製

序列化

#序列化-->傳輸-->反序列化

package main

import (    "fmt"
    "encoding/json")

type Student struct {
    Name    string
    Age        int
    Guake    bool
    Classes    []string
    Price    float32
}

func (s * Student)ShowStu() {    fmt.Println("show Student :")    fmt.Println("\tName\t:", s.Name)    fmt.Println("\tAge\t:", s.Age)    fmt.Println("\tGuake\t:", s.Guake)    fmt.Println("\tPrice\t:", s.Price)    fmt.Printf("\tClasses\t: ")    for _, a := range s.Classes {        fmt.Printf("%s ", a)
    }    fmt.Println("")
}

func main() {
    st := &Student {        "Xiao Ming",        16,        true,
        []string{"Math", "English", "Chinese"},        9.99,
    }    fmt.Println("before JSON encoding :")
    st.ShowStu()

    b, err := json.Marshal(st)    if err != nil {        fmt.Println("encoding faild")
    } else {        fmt.Println("encoded data : ")        fmt.Println(b)        fmt.Println(string(b))
    }
    ch := make(chan string, 1)
    go func(c chan string, str string){
        c <- str
    }(ch, string(b))
    strData := <-ch    fmt.Println("--------------------------------")
    stb := &Student{}
    stb.ShowStu()
    err = json.Unmarshal([]byte(strData), &stb)    if err != nil {        fmt.Println("Unmarshal faild")
    } else {        fmt.Println("Unmarshal success")
        stb.ShowStu()
    }
}
登入後複製

範例

json 資料編碼和解碼  json 套件提供了Decoder 和Encoder 類型來支援常用json 資料流讀寫。 NewDecoder 和 NewEncoder 函式分別封裝了 io.Reader 和 io.Writer 介面。

package main

import (    "encoding/json"
    "fmt"
    "os"
    "strings")

type People struct {
    name   string  `json:"name"` // name,小写不导出
    Age    int     `json:"age"`  // age,在 json 字符串中叫 age
    Gender string `json:"gender"`  // gender    Lesson
}

type Lesson struct {
    Lessons []string `json:"lessons"`
}

func main() {

    jsonStr := `{"Age": 18,"name": "Jim" ,"gender": "男","lessons":["English","History"],"Room":201,"n":null,"b":false}`
    strR := strings.NewReader(jsonStr)
    people := &People{}    // 用 NewDecoder && Decode 进行解码给定义好的结构体对象 people
    err := json.NewDecoder(strR).Decode(people)    if err != nil {        fmt.Println(err)
    }    fmt.Printf("%+v",people)   //

    // 用 NewEncoder && Encode 把保存的 people 结构体对象编码为 json 保存到文件
    f, err := os.Create("./people.json")
    json.NewEncoder(f).Encode(people)

}
登入後複製

範例

package main

import (
    "encoding/json"
    "fmt"
    "os"
    "strings"
)

type People struct {
    name   string  `json:"name"` // name,小写不导出
    Age    int     `json:"age"`  // age,在 json 字符串中叫 age
    Gender string `json:"gender"`  // gender
    Lesson
}

type Lesson struct {
    Lessons []string `json:"lessons"`
}

func main() {

    jsonStr := `{"Age": 18,"name": "Jim" ,"gender": "男","lessons":["English","History"],"Room":201,"n":null,"b":false}`
    strR := strings.NewReader(jsonStr)
    people := &People{}

    // 用 NewDecoder && Decode 进行解码给定义好的结构体对象 people
    err := json.NewDecoder(strR).Decode(people)
    if err != nil {
        fmt.Println(err)
    }
    fmt.Printf("%+v",people)   //

    // 用 NewEncoder && Encode 把保存的 people 结构体对象编码为 json 保存到文件
    f, err := os.Create("./people.json")
    json.NewEncoder(f).Encode(people)

}

示例
登入後複製

##

以上是介紹Golang序列化和反序列化的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:cnblogs.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板