다음은 golang 튜토리얼 칼럼에 나온 Golang 직렬화 및 역직렬화에 대한 소개입니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다!
데이터 객체를 네트워크를 통해 전송하거나 파일에 저장하려면 인코딩 및 디코딩해야 합니다. 현재 json, XML 등 다양한 인코딩 형식이 있습니다. , Gob, Google Protocol Buffer 등. 물론 Go 언어는 이러한 인코딩 형식도 모두 지원합니다.
직렬화(Serialization)는 객체의 상태 정보를 저장하거나 전송할 수 있는 형식으로 변환하는 프로세스입니다. 직렬화 중에 객체는 현재 상태를 임시 또는 영구 저장소에 씁니다. 저장 영역에서 객체의 상태를 읽어 객체를 다시 생성하는 것은 역직렬화입니다
Go 유형
string strings
nil > 인터페이스를 사용하여 수신됩니다. {}, 위의 규칙에 따라 파싱되어야 합니다.
코드 데모
역직렬화
package main import ( "encoding/json" "fmt") type People struct { name string `json:"name"` // name,小写不导出 Age int `json:"age"` // age Gender string `json:"gender"` // gender Lesson } type Lesson struct { Lessons []string `json:"lessons"` } func main() { jsonstr := `{"Age": 18,"name": "Jim" ,"gender": "男","lessons":["English","History"],"Room":201,"n":null,"b":false}` // 反序列化 var people People if err := json.Unmarshal([]byte(jsonstr),&people); err == nil { fmt.Println("struct people:") fmt.Println(people) } // 反序列化 json 字符串中的一部分 var lessons Lesson if err := json.Unmarshal([]byte(jsonstr),&lessons); err == nil { fmt.Println("struct lesson:") fmt.Println(lessons) } // 反序列化 json 字符串数组 jsonstr = `["English","History"]` var str []string if err := json.Unmarshal([]byte(jsonstr), &str); err == nil { fmt.Println("struct str:") fmt.Println(str) } }// 打印结果 struct people: { 18 男 {[English History]}} struct lesson: {[English History]} struct str: [English History]
직렬화
package main import ( "encoding/json" "fmt") type People struct { name string `json:"name"` // name,小写不导出 Age int `json:"age"` // age,在 json 字符串中叫 age Gender string `json:"gender"` // gender Lesson } type Lesson struct { Lessons []string `json:"lessons"` } func main() { lesson := Lesson{[]string{"Math","English","Chinese"}} people := &People{ name: "amy", Age: 22, Gender: "female", Lesson: lesson, } if b, err := json.Marshal(people); err != nil { fmt.Println("Marshal failed...") }else { fmt.Println(b) fmt.Println(string(b)) } } // 打印结果 [123 34 97 103 101 34 58 50 50 44 34 103 101 110 100 101 114 34 58 34 102 101 109 97 108 101 34 44 34 108 101 115 115 111 110 115 34 58 91 34 77 97 116 104 34 44 34 69 110 103 108 105 115 104 34 44 34 67 104 105 110 101 115 101 34 93 125] {"age":22,"gender":"female","lessons["Math","English","Chinese“}
직렬화 --> 전송 --> 역직렬화
package main import ( "fmt" "encoding/json") type Student struct { Name string Age int Guake bool Classes []string Price float32 } func (s * Student)ShowStu() { fmt.Println("show Student :") fmt.Println("\tName\t:", s.Name) fmt.Println("\tAge\t:", s.Age) fmt.Println("\tGuake\t:", s.Guake) fmt.Println("\tPrice\t:", s.Price) fmt.Printf("\tClasses\t: ") for _, a := range s.Classes { fmt.Printf("%s ", a) } fmt.Println("") } func main() { st := &Student { "Xiao Ming", 16, true, []string{"Math", "English", "Chinese"}, 9.99, } fmt.Println("before JSON encoding :") st.ShowStu() b, err := json.Marshal(st) if err != nil { fmt.Println("encoding faild") } else { fmt.Println("encoded data : ") fmt.Println(b) fmt.Println(string(b)) } ch := make(chan string, 1) go func(c chan string, str string){ c <- str }(ch, string(b)) strData := <-ch fmt.Println("--------------------------------") stb := &Student{} stb.ShowStu() err = json.Unmarshal([]byte(strData), &stb) if err != nil { fmt.Println("Unmarshal faild") } else { fmt.Println("Unmarshal success") stb.ShowStu() } }
json 데이터 인코딩 및 디코딩
json 패키지는 일반적인 json 데이터 스트림 읽기 및 쓰기를 지원하는 디코더 및 인코더 유형을 제공합니다. NewDecoder 및 NewEncoder 함수는 각각 io.Reader 및 io.Writer 인터페이스를 캡슐화합니다.
package main import ( "encoding/json" "fmt" "os" "strings") type People struct { name string `json:"name"` // name,小写不导出 Age int `json:"age"` // age,在 json 字符串中叫 age Gender string `json:"gender"` // gender Lesson } type Lesson struct { Lessons []string `json:"lessons"` } func main() { jsonStr := `{"Age": 18,"name": "Jim" ,"gender": "男","lessons":["English","History"],"Room":201,"n":null,"b":false}` strR := strings.NewReader(jsonStr) people := &People{} // 用 NewDecoder && Decode 进行解码给定义好的结构体对象 people err := json.NewDecoder(strR).Decode(people) if err != nil { fmt.Println(err) } fmt.Printf("%+v",people) // // 用 NewEncoder && Encode 把保存的 people 结构体对象编码为 json 保存到文件 f, err := os.Create("./people.json") json.NewEncoder(f).Encode(people) }
예
package main import ( "encoding/json" "fmt" "os" "strings" ) type People struct { name string `json:"name"` // name,小写不导出 Age int `json:"age"` // age,在 json 字符串中叫 age Gender string `json:"gender"` // gender Lesson } type Lesson struct { Lessons []string `json:"lessons"` } func main() { jsonStr := `{"Age": 18,"name": "Jim" ,"gender": "男","lessons":["English","History"],"Room":201,"n":null,"b":false}` strR := strings.NewReader(jsonStr) people := &People{} // 用 NewDecoder && Decode 进行解码给定义好的结构体对象 people err := json.NewDecoder(strR).Decode(people) if err != nil { fmt.Println(err) } fmt.Printf("%+v",people) // // 用 NewEncoder && Encode 把保存的 people 结构体对象编码为 json 保存到文件 f, err := os.Create("./people.json") json.NewEncoder(f).Encode(people) } 示例
위 내용은 Golang 직렬화 및 역직렬화 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!