下面由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}
尼玛… 结构体成员(golang叫字段)小写…,突然想起来关于包级的变量名和函数名,小写相当于private… 难道是这样?
马上改了:
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}
尼玛… 结构体成员(golang叫字段)小写…,突然想起来关于包级的变量名和函数名,小写相当于private… 难道是这样?
马上改了:
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中文网其他相关文章!

Go语言的核心特性包括垃圾回收、静态链接和并发支持。1.Go语言的并发模型通过goroutine和channel实现高效并发编程。2.接口和多态性通过实现接口方法,使得不同类型可以统一处理。3.基本用法展示了函数定义和调用的高效性。4.高级用法中,切片提供了动态调整大小的强大功能。5.常见错误如竞态条件可以通过gotest-race检测并解决。6.性能优化通过sync.Pool重用对象,减少垃圾回收压力。

Go语言在构建高效且可扩展的系统中表现出色,其优势包括:1.高性能:编译成机器码,运行速度快;2.并发编程:通过goroutines和channels简化多任务处理;3.简洁性:语法简洁,降低学习和维护成本;4.跨平台:支持跨平台编译,方便部署。

关于SQL查询结果排序的疑惑学习SQL的过程中,常常会遇到一些令人困惑的问题。最近,笔者在阅读《MICK-SQL基础�...

golang ...

Go语言中如何对比并处理三个结构体在Go语言编程中,有时需要对比两个结构体的差异,并将这些差异应用到第�...

GoLand中自定义结构体标签不显示怎么办?在使用GoLand进行Go语言开发时,很多开发者会遇到自定义结构体标签在�...


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3 Linux新版
SublimeText3 Linux最新版

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

SublimeText3汉化版
中文版,非常好用

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。