go语言基础 -- json的序列化

json序列化

package main
import(
    "fmt"
    "encoding/json"
)

type Monster struct{
    Name string
    Age int
    Skill string
}

// 结构体序列化
func serialize_struct() {
    monster := Monster{
        Name : "niumo",
        Age : 500,
        Skill : "bajiaoshan",
    }
    // 这里传指针主要是减少拷贝
    data, err := json.Marshal(&monster)
    if err != nil {
        fmt.Printf("trans to json failed")
    }
    fmt.Printf("%v", string(data))
}

// map序列化
func serialize_map() {
    // 定义一个interface做value的的map,可以让interface存储任意类型
    var a map[string]interface{}
    a = make(map[string]interface{})
    a["zhu"] = "bajie"
    a["hou"] = "wukong"
    a["num"] = 4
    // 引用类型不需要传地址
    data, err := json.Marshal(a)
}

// 切片序列化
func serialize_slice() {
    var slice []map[string]interface{}
    var m1 map[string]interface{}
    m1 = make(map[string]interface{})
    m1["name"] = "jack"
    m1["age"] = 10
    m2 = make(map[string]interface{})
    m2["name"] = "tom"
    m2["age"] = 20
    slice = append(slice, m1)
    slice.append(slice, m2)
    data, err := json.Marshal(slice)
}

// 基本数据类型序列化
func testFloat() {
    var num float64 = 24.56
    json.Marshal(&num)
}
func main() {

}

结构体要序列化成自己的标签名字看我们前面的文章即可,此处不再赘述

json反序列化

func unserialize_struct() {
    str := "{\"Age\":20,\"Name\":\"xiaodu\",\"Skill\":\"hit\"}"
    var monster Monster
    // 这里必须传monster指针
    err := json.Unmarshal([]byte[str], &monster)
}

反序列化map类似,反序列化map时不需要通过make来开辟空间,Unmarshal里面会进行make,同时map字段的顺序需要严格一致。

  • 12
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
您好,关于您的问题,Go语言中使用标准库中的json包进行序列化和反序列化操作。具体实现方法如下: 1. 对于结构体的序列化和反序列化操作 首先定义一个结构体,该结构体中的字段必须是导出(首字母大写)的,方可被序列化和反序列化。 例如: ```go type Person struct { Name string `json:"name"` Age int `json:"age"` } ``` 在定义好结构体之后,即可使用json包中的Marshal函数进行序列化操作,使用Unmarshal函数进行反序列化操作。 例如: ```go // 序列化 p := Person{Name: "Tom", Age: 18} bytes, err := json.Marshal(p) if err != nil { // 处理错误 } fmt.Println(string(bytes)) // {"name":"Tom","age":18} // 反序列化 var person Person err = json.Unmarshal(bytes, &person) if err != nil { // 处理错误 } fmt.Println(person.Name) // Tom fmt.Println(person.Age) // 18 ``` 2. 对于map、slice等类型的序列化和反序列化操作 对于map、slice等类型,直接使用json包中的Marshal函数进行序列化操作,使用Unmarshal函数进行反序列化操作即可。 例如: ```go // map序列化 m := map[string]interface{}{ "name": "Tom", "age": 18, } bytes, err := json.Marshal(m) if err != nil { // 处理错误 } fmt.Println(string(bytes)) // {"age":18,"name":"Tom"} // map反序列化 var data map[string]interface{} err = json.Unmarshal(bytes, &data) if err != nil { // 处理错误 } fmt.Println(data["name"]) // Tom fmt.Println(data["age"]) // 18 // slice序列化 s := []string{"hello", "world"} bytes, err := json.Marshal(s) if err != nil { // 处理错误 } fmt.Println(string(bytes)) // ["hello","world"] // slice反序列化 var data []string err = json.Unmarshal(bytes, &data) if err != nil { // 处理错误 } fmt.Println(data[0]) // hello fmt.Println(data[1]) // world ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值