package scripts_stroage
import (
"encoding/json"
"fmt"
"testing"
)
// 反序列化时,如果不传对应 json里面的字段,就会解析为 对应数据类型的 "零值"
type TestStruct1 struct {
Name string `json:"name"`
Age int `json:"age"`
IsBoy bool `json:"is_boy"`
}
// 类型是指针类型
// 序列化时,如果不指定value,就会被解析成 null(json的空值)
//反序列化时,如果不传对应 json里面的字段,就会解析为 nil
type TestStruct2 struct {
Name *string `json:"name"`
Age *int `json:"age"`
IsBoy *bool `json:"is_boy"`
}
func TestST1(t *testing.T) {
// -------------- 序列化测试 ----------------
// 1、序列化成一个字符串,有默认值
t1 := TestStruct1{}
data1, _ := json.Marshal(t1)
fmt.Printf("data1: %s \n", data1) // {"name":"","age":0,"is_boy":false}
// 2、序列化成一个字符串,默认都序列化成了 null !!!
t2 := TestStruct2{}
data2, _ := json.Marshal(t2)
fmt.Printf("data2: %s \n", data2) // data2: {"name":null,"age":null,"is_boy":null}
// -------------- 反序列化测试 ----------------
fmt.Println("===================================================")
s := `{"gender":"male"}` // 没有json指定的字段~
// 用第一个反序列化 返回:字符串、数字、bool值 的默认值
var sObj1 TestStruct1
_ = json.Unmarshal([]byte(s), &sObj1)
fmt.Println("sRet1: ", sObj1.Name, sObj1.Age, sObj1.IsBoy) // sRet1: 0 false
// TODO 用第二个反序列化 返回:三个nil!!!因为我们是用指针去反序列化的,指针的默认值就是nil
var sObj2 TestStruct2
_ = json.Unmarshal([]byte(s), &sObj2)
fmt.Println("sRet2: ", sObj2.Name, sObj2.Age, sObj2.IsBoy) // sRet2: <nil> <nil> <nil>
// TODO 第二种方法反序列化出来以后,再次赋值,注意只能用变量去设置,因为我们可以取到变量的地址,但是不能获取常量的地址
defaultName := "whw"
defaultAge := 22
defaultBoy := true
if sObj2.Name == nil {
sObj2.Name = &defaultName
}
if sObj2.Age == nil {
sObj2.Age = &defaultAge
}
if sObj2.IsBoy == nil {
sObj2.IsBoy = &defaultBoy
}
// TODO 因为是指针,所以用 * 去取value
fmt.Println("sRet2再次初始化: ", *sObj2.Name, *sObj2.Age, *sObj2.IsBoy) // sRet2再次初始化: whw 22 true
}


~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
序列化结果不想带一些属性的零值—>加omitempty标签

写一个方法去返回 *bool 解析后的值并根据业务需求设置默认值


~~~~~~~~~~~~~~~~~~
















