Golang中Json的序列化和反序列化的使用
更新時(shí)間:2022年04月21日 12:05:03 作者:itzhuzhu.
本文主要介紹了Golang中Json的序列化和反序列化的使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
JSON:
- JSON(JavaScript Object Notation):是一種輕量級(jí)的數(shù)據(jù)交換格式。 它是基于 ECMAScript 規(guī)范的一個(gè)子集,采用完全獨(dú)立于編程語言的文本格式來存儲(chǔ)和表示數(shù)據(jù)。
- 簡(jiǎn)潔和清晰的層次結(jié)構(gòu)使得 JSON 成為理想的數(shù)據(jù)交換語言。易于人閱讀和編寫,同時(shí)也易于計(jì)算機(jī)解析和生成,并有效的 提升網(wǎng)絡(luò)傳輸效率。
- Json易于機(jī)器解析和生成,并有效的提升網(wǎng)絡(luò)傳輸效率,通常程序傳輸時(shí)會(huì)先將數(shù)據(jù)序列化成json字符串,接收方再反序列化成原數(shù)據(jù)類型
- 所有的數(shù)據(jù)類型都可以通過Json表示
- Json.cn這個(gè)網(wǎng)站可以驗(yàn)證Json格式
- 序列化用json.Marshal()
- 反序列化用json.Unmarshal(),反序列化時(shí)要和序列化前的數(shù)據(jù)類型保持一致
創(chuàng)建格式:

基本數(shù)據(jù)類型序列化:
func testBasic() {
num := 1.111
marshal, err := json.Marshal(num)
if err != nil {
fmt.Println("json.Marshal err:", err)
}
fmt.Println("序列化后:", string(marshal)) // 序列化后: 1.111
}
結(jié)構(gòu)體序列化:
func main() {
testStudent()
}
/**
type Student struct {
Name string
Age int
Birthday string
Address string
}
*/
// 如果加上`json:"student_name"`,序列化以后的數(shù)據(jù)字段是返回指定格式的,可以小寫,json固定,后面的隨意
type Student struct {
// 變量首字母大寫才能被解析
Name string `json:"student_name"`
Age int `json:"student_age"`
Birthday string `json:"student_birthday"`
Address string `json:"student_address"`
}
func testStudent() {
student := Student{
Name: "itzhuzhu",
Age: 24,
Birthday: "1998-01-01",
Address: "廣州市天河區(qū)",
}
marshal, err := json.Marshal(&student)
if err != nil {
fmt.Println("json.Marshal err:", err)
}
fmt.Println("序列化后:", string(marshal)) // 序列化后:{"Name":"itzhuzhu","Age":24,"Birthday":"1998-01-01","Address":"廣州市天河區(qū)"}
}
map序列化:
func testMap() {
var m map[string]interface{}
m = make(map[string]interface{})
m["name"] = "韓信"
m["age"] = 23
m["address"] = "廣州"
marshal, err := json.Marshal(m)
if err != nil {
fmt.Println("json.Marshal err:", err)
}
fmt.Println("序列化后:", string(marshal)) // 序列化后: {"address":"廣州","age":23,"name":"韓信"}
}
切片序列化:
func testSlice() {
var slice []map[string]interface{}
var m map[string]interface{}
m = make(map[string]interface{})
m["name"] = "韓信"
m["age"] = 23
m["address"] = "廣州"
slice = append(slice, m)
marshal, err := json.Marshal(m)
if err != nil {
fmt.Println("json.Marshal err:", err)
}
fmt.Println("序列化后:", string(marshal)) // 序列化后: {"address":"廣州","age":23,"name":"韓信"}
}
反序列化為結(jié)構(gòu)體:
func deserialize() {
str := "{\"Name\":\"itzhuzhu\",\"Age\":24,\"Birthday\":\"1998-01-01\",\"Address\":\"廣州市天河區(qū)\"}"
// 使用Unmarshal反序列化
var student Student
err := json.Unmarshal([]byte(str), &student)
if err != nil {
fmt.Println("json.Unmarshal err:", err)
}
fmt.Println("反序列化后:", student) // 反序列化后: {itzhuzhu 24 1998-01-01 廣州市天河區(qū)}
}
反序列化為map:
func deserializeMap() {
str := " {\"address\":\"廣州\",\"age\":23,\"name\":\"韓信\"}"
// 反序列化的時(shí)候不需要make,被封裝到Unmarshal中了
var m map[string]interface{}
err := json.Unmarshal([]byte(str), &m)
if err != nil {
fmt.Println("json.Unmarshal err:", err)
}
fmt.Println("反序列化后:", m) // map[address:廣州 age:23 name:韓信]
}
反序列化為切片:
func deserializeSlice() {
str := " [{\"address\":\"廣州\",\"age\":23,\"name\":\"韓信\"}]"
var slice []map[string]interface{}
err := json.Unmarshal([]byte(str), &slice)
if err != nil {
fmt.Println("json.Unmarshal err:", err)
}
fmt.Println("反序列化后:", slice) // 反序列化后: [map[address:廣州 age:23 name:韓信]]
}
到此這篇關(guān)于Golang中Json的序列化和反序列化的使用的文章就介紹到這了,更多相關(guān)Golang Json序列化和反序列化內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Go獲取兩個(gè)時(shí)間點(diǎn)時(shí)間差的具體實(shí)現(xiàn)
本文主要介紹了Go獲取兩個(gè)時(shí)間點(diǎn)時(shí)間差的具體實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
Golang實(shí)現(xiàn)HTTP代理突破IP訪問限制的步驟詳解
在當(dāng)今互聯(lián)網(wǎng)時(shí)代,網(wǎng)站和服務(wù)商為了維護(hù)安全性和保護(hù)用戶隱私,常常會(huì)對(duì)特定的IP地址進(jìn)行封鎖或限制,本文將介紹如何使用Golang實(shí)現(xiàn)HTTP代理來突破IP訪問限制,需要的朋友可以參考下2023-10-10
go語言調(diào)用其他包中的函數(shù)簡(jiǎn)單示例
這篇文章主要給大家介紹了關(guān)于go語言調(diào)用其他包中的函數(shù)的相關(guān)資料,文中還介紹了Go語言同一個(gè)包中不同文件之間函數(shù)調(diào)用的相關(guān)問題,需要的朋友可以參考下2023-01-01

