Golang json用法詳解(一)


Golang json用法詳解(一)

簡介

json格式可以算我們日常最常用的序列化格式之一了,Go語言作為一個由Google開發,號稱互聯網的C語言的語言,自然也對JSON格式支持很好。但是Go語言是個強類型語言,對格式要求極其嚴格而JSON格式雖然也有類型,但是並不穩定,Go語言在解析來源為非強類型語言時比如PHP等序列化的JSON時,經常遇到一些問題諸如字段類型變化導致無法正常解析的情況,導致服務不穩定。所以本篇的主要目的

  1. 就是挖掘Golang解析json的絕大部分能力
  2. 比較優雅的解決解析json時存在的各種問題
  3. 深入一下Golang解析json的過程

Golang解析JSON之Tag篇

  1. 一個結構體正常序列化過后是什么樣的呢?

    package main
    import (
        "encoding/json"
        "fmt"
    )
    
    // Product 商品信息
    type Product struct {
        Name      string
        ProductID int64
        Number    int
        Price     float64
        IsOnSale  bool
    }
    
    func main() {
        p := &Product{}
        p.Name = "Xiao mi 6"
        p.IsOnSale = true
        p.Number = 10000
        p.Price = 2499.00
        p.ProductID = 1
        data, _ := json.Marshal(p)
        fmt.Println(string(data))
    }
    
    
    //結果
    {"Name":"Xiao mi 6","ProductID":1,"Number":10000,"Price":2499,"IsOnSale":true}
    
  2. 何為Tag,tag就是標簽,給結構體的每個字段打上一個標簽,標簽冒號前是類型,后面是標簽名。

    // Product _
    type Product struct {
        Name      string  `json:"name"`
        ProductID int64   `json:"-"` // 表示不進行序列化
        Number    int     `json:"number"`
        Price     float64 `json:"price"`
        IsOnSale  bool    `json:"is_on_sale,string"`
    }
    
    // 序列化過后,可以看見
    {"name":"Xiao mi 6","number":10000,"price":2499,"is_on_sale":"false"}
    
  3. omitempty,tag里面加上omitempy,可以在序列化的時候忽略0值或者空值

    package main
    
    import (
        "encoding/json"
        "fmt"
    )
    
    // Product _
    type Product struct {
        Name      string  `json:"name"`
        ProductID int64   `json:"product_id,omitempty"` 
        Number    int     `json:"number"`
        Price     float64 `json:"price"`
        IsOnSale  bool    `json:"is_on_sale,omitempty"`
    }
    
    func main() {
        p := &Product{}
        p.Name = "Xiao mi 6"
        p.IsOnSale = false
        p.Number = 10000
        p.Price = 2499.00
        p.ProductID = 0
    
        data, _ := json.Marshal(p)
        fmt.Println(string(data))
    }
    // 結果
    {"name":"Xiao mi 6","number":10000,"price":2499}
    
  4. type,有些時候,我們在序列化或者反序列化的時候,可能結構體類型和需要的類型不一致,這個時候可以指定,支持string,number和boolean

    package main
    
    import (
        "encoding/json"
        "fmt"
    )
    
    // Product _
    type Product struct {
        Name      string  `json:"name"`
        ProductID int64   `json:"product_id,string"`
        Number    int     `json:"number,string"`
        Price     float64 `json:"price,string"`
        IsOnSale  bool    `json:"is_on_sale,string"`
    }
    
    func main() {
    
        var data = `{"name":"Xiao mi 6","product_id":"10","number":"10000","price":"2499","is_on_sale":"true"}`
        p := &Product{}
        err := json.Unmarshal([]byte(data), p)
        fmt.Println(err)
        fmt.Println(*p)
    }
    // 結果
    <nil>
    {Xiao mi 6 10 10000 2499 true}
    


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM