다음 튜토리얼 칼럼인 golang에서는 Go 언어 피트 녹음 gob 직렬화 피트가 필요한 친구들에게 도움이 되길 바랍니다!
package mainimport ( "bytes" "encoding/gob" "fmt" "log" "os")func main() { /// 序列化编码&写入文件开始 /// // 实例化一个学生对象s1 s1 := &Student{id: 1, name: "jack ma", age: 2, cash: 43242334.35} // 实例化一个gob编码对象,并对s1学生对象进行编码 var buf bytes.Buffer encoder := gob.NewEncoder(&buf) error2Log("Encode: ", encoder.Encode(s1)) // 输出序列化后的类容 fmt.Printf("Serialized: %x\n", buf.Bytes()) // 创建data.data文件,存放序列化数据 fs, err := os.Create("./data.data") error2Log("Creat File: ", err) // 写入数据,并打印写入数据长度 wlen, err := fs.Write(buf.Bytes()) error2Log("Write file: ", err) fmt.Println("Wirte bytes:", wlen) fs.Close() /// 序列化编码&写入文件结束 /// /// 读入文件&反序列化编码开始 /// // 从文件打开写入的序列化数据 fs, err = os.Open("./data.data") error2Log("Open file: ", err) // 获取文件信息接口 finfo, err := fs.Stat() error2Log("Get fileinfo: ", err) // 根据文件大小创建字节数组,然后将文件中数据读入到字节数组中,并打印读入数据长度 readBuf := make([]byte, finfo.Size()) rlen, err := fs.Read(readBuf) error2Log("Read file: ", err) fmt.Println("Read bytes:", rlen) fs.Close() // 实例化一个用于接收反序列化数据的学生对象 s2 := new(Student) // 实例化一个gob解码对象 decoder := gob.NewDecoder(bytes.NewReader(readBuf)) // 将数据解码到学生对象s2 error2Log("Decode: ", decoder.Decode(s2)) // 将反序列化后的数据,s2学生对象打印出来 fmt.Println("Unserialized:", s2) /// 读入文件&反序列化编码结束 ///}func error2Log(m string, e error) { if e != nil { log.Fatal(m, e) }}// Student 学生对象type Student struct { id uint64 name string age uint cash float64}
컴파일 후 실행 구조는 다음과 같습니다.
2019/04/17 15:07:46 Encode: gob: type main.Student has no exported fields
한 시간 넘게 우울했습니다. 다음과 같은 몇 가지 정보를 확인했습니다.
https://github.com/golang/go/issues/5819
하지만 이것은 제가 필요한 문제에 대한 해결책이 아닙니다. 단지 구조 개체를 파일에 쓰고 싶습니다. . 그리고 구조를 삽입할 계획이 없습니다.
그러다가 갑자기 영감이 떠올랐고 아주 멍청한 실수를 했습니다:
type Student struct { id uint64 name string age uint cash float64}
Nima... 구조체 멤버(Golang에서는 필드라고 함)는 소문자입니다... 갑자기 패키지 수준 변수 이름과 함수에 대한 것이 생각났습니다. 이름, 소문자는 비공개와 동일합니다... 그럴까요?
즉시 변경됨:
type Student struct { ID uint64 Name string Age uint Cash float64}
라인 14의 인스턴스화 s1이 다음으로 변경되었습니다.
s1 := &Student{ID: 1, Name: "jack ma", Age: 2, Cash: 43242334.35}
그러면 컴파일 및 실행 구조가 마침내 정확해졌습니다.
Serialized: 36ff810301010753747564656e7401ff820001040102494401060001044e616d65010c00010341676501060001044361736801080000001aff82010101076a61636b206d61010201f8cdccccf29a9e844100 Wirte bytes: 82 Read bytes: 82 Unserialized: &{1 jack ma 2 4.324233435e+07}
이는 golang에서 개발되지 않은 코딩 습관을 되돌아보는 것과 같습니다.
따라서 앞으로 구조를 작성할 때는 좋은 습관을 길러야 합니다. 즉, 필드 이름은 대문자를 사용해야 합니다. (555555555555555~)
package mainimport ( "bytes" "encoding/gob" "fmt" "log" "os")func main() { /// 序列化编码&写入文件开始 /// // 实例化一个学生对象s1 s1 := &Student{id: 1, name: "jack ma", age: 2, cash: 43242334.35} // 实例化一个gob编码对象,并对s1学生对象进行编码 var buf bytes.Buffer encoder := gob.NewEncoder(&buf) error2Log("Encode: ", encoder.Encode(s1)) // 输出序列化后的类容 fmt.Printf("Serialized: %x\n", buf.Bytes()) // 创建data.data文件,存放序列化数据 fs, err := os.Create("./data.data") error2Log("Creat File: ", err) // 写入数据,并打印写入数据长度 wlen, err := fs.Write(buf.Bytes()) error2Log("Write file: ", err) fmt.Println("Wirte bytes:", wlen) fs.Close() /// 序列化编码&写入文件结束 /// /// 读入文件&反序列化编码开始 /// // 从文件打开写入的序列化数据 fs, err = os.Open("./data.data") error2Log("Open file: ", err) // 获取文件信息接口 finfo, err := fs.Stat() error2Log("Get fileinfo: ", err) // 根据文件大小创建字节数组,然后将文件中数据读入到字节数组中,并打印读入数据长度 readBuf := make([]byte, finfo.Size()) rlen, err := fs.Read(readBuf) error2Log("Read file: ", err) fmt.Println("Read bytes:", rlen) fs.Close() // 实例化一个用于接收反序列化数据的学生对象 s2 := new(Student) // 实例化一个gob解码对象 decoder := gob.NewDecoder(bytes.NewReader(readBuf)) // 将数据解码到学生对象s2 error2Log("Decode: ", decoder.Decode(s2)) // 将反序列化后的数据,s2学生对象打印出来 fmt.Println("Unserialized:", s2) /// 读入文件&反序列化编码结束 ///}func error2Log(m string, e error) { if e != nil { log.Fatal(m, e) }}// Student 学生对象type Student struct { id uint64 name string age uint cash float64}
컴파일된 실행 구조는 다음과 같습니다.
2019/04/17 15:07:46 Encode: gob: type main.Student has no exported fields
한 시간 넘게 우울했습니다. 다음과 같은 몇 가지 정보를 확인했습니다.
https://github.com/golang/go/issues/5819
하지만 이것은 제가 필요한 문제에 대한 해결책이 아닙니다. 또한 구조 개체를 파일에 쓰고 싶습니다. 구조를 삽입할 계획은 없습니다.
그러다가 갑자기 영감이 떠올랐고 아주 멍청한 실수를 했습니다:
type Student struct { id uint64 name string age uint cash float64}
Nima... 구조체 멤버(Golang에서는 필드라고 함)는 소문자입니다... 갑자기 패키지 수준 변수 이름과 함수에 대한 것이 생각났습니다. 이름, 소문자는 비공개와 동일합니다... 그럴까요?
즉시 변경됨:
type Student struct { ID uint64 Name string Age uint Cash float64}
라인 14의 인스턴스화 s1이 다음으로 변경되었습니다.
s1 := &Student{ID: 1, Name: "jack ma", Age: 2, Cash: 43242334.35}
그러면 컴파일 및 실행 구조가 마침내 정확해졌습니다.
Serialized: 36ff810301010753747564656e7401ff820001040102494401060001044e616d65010c00010341676501060001044361736801080000001aff82010101076a61636b206d61010201f8cdccccf29a9e844100 Wirte bytes: 82 Read bytes: 82 Unserialized: &{1 jack ma 2 4.324233435e+07}
이는 golang에서 개발되지 않은 코딩 습관을 되돌아보는 것과 같습니다.
따라서 앞으로 구조를 작성할 때 좋은 습관을 길러야 합니다. 즉, 필드 이름은 대문자를 사용해야 합니다. (555555555555555~)
위 내용은 Go 언어 채굴 피트를 기록하고 Gob 직렬화 피트를 기록합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!