>백엔드 개발 >Golang >Go 언어 채굴 피트를 기록하고 Gob 직렬화 피트를 기록합니다.

Go 언어 채굴 피트를 기록하고 Gob 직렬화 피트를 기록합니다.

藏色散人
藏色散人앞으로
2021-03-26 17:18:042913검색

다음 튜토리얼 칼럼인 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제