91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

GoLang之標準庫encoding/json包怎么使用

發布時間:2022-08-17 15:59:35 來源:億速云 閱讀:171 作者:iii 欄目:開發技術

這篇文章主要介紹了GoLang之標準庫encoding/json包怎么使用的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇GoLang之標準庫encoding/json包怎么使用文章都會有所收獲,下面我們一起來看看吧。

注:本文以Windos系統上Go SDK v1.8進行講解

1.JSON介紹

在進行前后分離式開發時,json顯得格外的重要,因為他是鏈接前后臺重要的樞紐
json是儲存和交換文本信息的語法,他類似于xml,但是他比xml更加的便捷,快速,易于解析。主要使用場景就是作為前后臺數據交互的樞紐,以下是一個簡單json的格式:
JSON: JavaScript Object Notation(JavaScript 對象標記法)。
JSON 是一種存儲和交換數據的語法。
JSON 是通過 JavaScript 對象標記法書寫的文本。
當數據在瀏覽器與服務器之間進行交換時,這些數據只能是文本。
JSON 屬于文本,并且我們能夠把任何 JavaScript 對象轉換為 JSON,然后將 JSON 發送到服務器。
我們也能把從服務器接收到的任何 JSON 轉換為 JavaScript 對象。
以這樣的方式,我們能夠把數據作為 JavaScript 對象來處理,無需復雜的解析和轉譯。
JSON 使用 JavaScript 語法,但是 JSON 格式是純文本的。
文本可被任何編程語言作為數據來讀取和使用。
JSON 格式最初由 Douglas Crockford 提出。
因為 JSON 格式僅僅是文本,它能夠輕松地在服務器瀏覽器之間傳輸,并用作任何編程語言的數據格式。
JSON(JavaScript Object Notation) 是一種輕量級的數據交換格式。易于人閱讀和編寫。同時也易于機器解析和生成。JSON鍵值對是用來保存JS對象的一種方式,鍵/值對組合中的鍵名寫在前面并用雙引號""包裹,使用冒號:分隔,然后緊接著值;多個鍵值之間使用英文,分隔

2.JSON序列化、反序列化介紹

json的序列化與反序列化介紹:
那么在說明如何解析Json和XML之前,我們先來搞清楚兩個概念:序列化和反序列化。
序列化,即Serialization,是一個將對象的狀態信息轉變為可以存儲或傳輸的形式的過程。
反序列化,即Deserialization,顧名思義是一個將可以存儲或傳輸的序列轉變為某個對象的狀態信息的過程。
1.這兩個過程互為逆過程;
2.無論是序列化還是反序列化,對象的狀態信息都與一段序列相對應。

3.encoding/json包介紹

GoLang之標準庫encoding/json包怎么使用

4.Marshal函數

GoLang之標準庫encoding/json包怎么使用

//Student 學生
type Student struct {
	ID     int
	Gender string
	Name   string
}

//Class 班級
type Class struct {
	Title    string
	Students []Student
}

//student的構造函數
func newStudent(id int, name string) Student {
	return Student{
		ID:   id,
		Name: name,
	}
}
func main() {
	//創建了一個班級變量
	c1 := Class{
		Title:    "101",
		Students: make([]Student, 0, 200),
	}
	//往班級變量中添加學生

	for i := 0; i < 10; i++ {
		tmpStu := newStudent(i, fmt.Sprintf("stu%02d,", i))
		c1.Students = append(c1.Students, tmpStu)
	}
	fmt.Println(c1)
	//輸出:{101 [{0  stu00,} {1  stu01,} {2  stu02,} {3  stu03,} {4  stu04,} {5  stu05,} {6  stu06,} {7  stu07,} {8  stu08,} {9  stu09,}]}
	//JSON序列化:結構體轉化為JSON格式的字符串
	data, err := json.Marshal(c1)
	if err != nil {
		fmt.Println("json marshal failed")
		return
	}
	fmt.Printf("%T\n", data) //[]uint8
	//fmt.Println(data)//盡量不要采用這樣的方式
	fmt.Println(string(data))
	/*輸出:{"Title":"101","Students":[{"ID":0,"Gender":"","Name":"stu00,"},{"ID":1,"Gender":"","Name":"stu01,"},{"ID":2,"Gender":"","Name":"stu02,"},
	{"ID":3,"Gender":"","Name":"stu03,"},{"ID":4,"Gender":"","Name":"stu04,"},{"ID":5,"Gender":"", "Name":"stu05,"},{"ID":6,"Gender":"","Name":"stu06,"},
	{"ID":7,"Gender":"","Name":"stu07,"},{"ID":8,"Gender":"","Name":"stu08,"},{"ID":9,"Gender":"","Name":"stu09,"}]}*/
}

//大寫例子
package main

import (
	"encoding/json"
	"fmt"
)

//Student 學生
type Student struct {
	ID     int
	Gender string
	Name   string
}

//Class 班級
type Class struct {
	title    string
	Students []Student
}

//student的構造函數
func newStudent(id int, name string) Student {
	return Student{
		ID:   id,
		Name: name,
	}
}
func main() {
	//創建了一個班級變量
	c1 := Class{
		title:    "101",
		Students: make([]Student, 0, 200),
	}
	//往班級變量中添加學生

	for i := 0; i < 10; i++ {
		tmpStu := newStudent(i, fmt.Sprintf("stu%02d,", i))
		c1.Students = append(c1.Students, tmpStu)
	}
	fmt.Println(c1)
	//輸出:{101 [{0  stu00,} {1  stu01,} {2  stu02,} {3  stu03,} {4  stu04,} {5  stu05,} {6  stu06,} {7  stu07,} {8  stu08,} {9  stu09,}]}
	//JSON序列化:結構體轉化為JSON格式的字符串
	data, err := json.Marshal(c1)
	if err != nil {
		fmt.Println("json marshal failed")
		return
	}
	fmt.Printf("%T\n", data) //[]uint8
	//fmt.Println(data)//盡量不要采用這樣的方式
	fmt.Println(string(data))
	/*輸出:{"Students":[{"ID":0,"Gender":"","Name":"stu00,"},{"ID":1,"Gender":"","Name":"stu01,"},{"ID":2,"Gender":"","Name":"stu02,"},
	  {"ID":3,"Gender":"","Name":"stu03,"},{"ID":4,"Gender":"","Name":"stu04,"},{"ID":5,"Gender":"", "Name":"stu05,"},{"ID":6,"Gender":"","Name":"stu06,"},
	  {"ID":7,"Gender":"","Name":"stu07,"},{"ID":8,"Gender":"","Name":"stu08,"},{"ID":9,"Gender":"","Name":"stu09,"}]}*/
}

//小寫例子,json包不能看到小寫字段的,所以小寫字段的不會被序列化

5.Umarshal函數 

GoLang之標準庫encoding/json包怎么使用

//Student 學生
type Student struct {
	ID     int
	Gender string
	Name   string
}
//Class 班級
type Class struct {
	Title    string
	Students []Student
}
//student的構造函數
func newStudent(id int, name string) Student {
	return Student{
		ID:   id,
		Name: name,
	}
}
func main() {
	//JSON反序列化:JSON格式的字符串轉化為結構體
	var c1 Class
	//str的內容使用反引號來標注的``
	str := `{"Title":"101","Students":[{"ID":0,"Gender":"男","Name":"stu00"},{"ID":1,"Gender":"男","Name":"stu01"},{"ID":2,"Gender":"男","Name":"stu02"},{"ID":3,"Gender":"男","Name":"stu03"},{"ID":4,"Gender":"男","Name":"stu04"},{"ID":5,"Gender":"男","Name":"stu05"},{"ID":6,"Gender":"男","Name":"stu06"},{"ID":7,"Gender":"男","Name":"stu07"},{"ID":8,"Gender":"男","Name":"stu08"},{"ID":9,"Gender":"男","Name":"stu09"}]}`
	err := json.Unmarshal([]byte(str), &c1) //第二個參數用來存放第一個參數的內容,c2需要被修改,想要被需改成功必須得傳入指針
	if err != nil {
		fmt.Println("json unmarshal failed!")
		return
	}
	fmt.Println(c1)
	//輸出:{101 [{0 男 stu00} {1 男 stu01} {2 男 stu02} {3 男 stu03} {4 男 stu04} {5 男 stu05} {6 男 stu06} {7 男 stu07} {8 男 stu08} {9 男 stu09}]}
}
//結構體大寫例子
//Student 學生
type Student struct {
	ID     int
	Gender string
	Name   string
}
//Class 班級
type Class struct {
	title    string
	Students []Student
}
//student的構造函數
func newStudent(id int, name string) Student {
	return Student{
		ID:   id,
		Name: name,
	}
}
func main() {
	//JSON反序列化:JSON格式的字符串轉化為結構體
	var c1 Class
	//str的內容使用反引號來標注的``
	str := `{"title":"101","Students":[{"ID":0,"Gender":"男","Name":"stu00"},{"ID":1,"Gender":"男","Name":"stu01"},{"ID":2,"Gender":"男","Name":"stu02"},{"ID":3,"Gender":"男","Name":"stu03"},{"ID":4,"Gender":"男","Name":"stu04"},{"ID":5,"Gender":"男","Name":"stu05"},{"ID":6,"Gender":"男","Name":"stu06"},{"ID":7,"Gender":"男","Name":"stu07"},{"ID":8,"Gender":"男","Name":"stu08"},{"ID":9,"Gender":"男","Name":"stu09"}]}`
	err := json.Unmarshal([]byte(str), &c1) //第二個參數用來存放第一個參數的內容,c2需要被修改,想要被需改成功必須得傳入指針
	if err != nil {
		fmt.Println("json unmarshal failed!")
		return
	}
	fmt.Println(c1)
	//輸出:{[{0 男 stu00} {1 男 stu01} {2 男 stu02} {3 男 stu03} {4 男 stu04} {5 男 stu05} {6 男 stu06} {7 男 stu07} {8 男 stu08} {9 男 stu09}]}
}
//小寫例子

6.結構體標簽Tag

Tag是結構體的元信息,可以在運行的時候通過反射的機制讀取出來。 Tag在結構體字段的后方定義,由一對反引號包裹起來,具體的格式如下:
key1:"value1" key2:"value2"
結構體tag由一個或多個鍵值對組成。鍵與值使用冒號分隔,值用雙引號括起來。同一個結構體字段可以設置多個鍵值對tag,不同的鍵值對之間使用空格分隔。
注意事項: 為結構體編寫Tag時,必須嚴格遵守鍵值對的規則。結構體標簽的解析代碼的容錯能力很差,一旦格式寫錯,編譯和運行時都不會提示任何錯誤,通過反射也無法正確取值。例如不要在key和value之間添加空格。

關于“GoLang之標準庫encoding/json包怎么使用”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“GoLang之標準庫encoding/json包怎么使用”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

牟定县| 大渡口区| 格尔木市| 河源市| 香格里拉县| 镇巴县| 连南| 金乡县| 仪征市| 达孜县| 遂宁市| 宁津县| 库尔勒市| 岳西县| 桑植县| 左权县| 肃宁县| 德钦县| 留坝县| 朝阳县| 赣榆县| 开阳县| 蓬溪县| 康马县| 福海县| 镇巴县| 望奎县| 高阳县| 应用必备| 吉林省| 衡东县| 都匀市| 博兴县| 济阳县| 濮阳市| 五寨县| 广平县| 竹北市| 嘉禾县| 蒙阴县| 梅州市|