内容简介:golang gencode 序列化/反序列化数据
andyleap/gencode 是一个快速的且体积很小的序列化库,速度是标准库10x倍。
首先定义数据结构:test.schema
struct Person {
Name string
Age uint8
}
然后通过gencode 命令行生成test.schema.gen.go:
$ gencode go -schema test.schema -package main
下面是结合bolt 来存储数据:
package main
import (
"fmt"
"log"
"time"
"github.com/boltdb/bolt"
)
func main() {
db, err := bolt.Open("my.db", 0600, &bolt.Options{Timeout: 1 * time.Second})
if err != nil {
log.Fatal(err)
}
defer db.Close()
db.Update(func(tx *bolt.Tx) error {
_, err := tx.CreateBucketIfNotExists([]byte("person"))
if err != nil {
return err
}
return nil
})
person := Person{
Name: "testname",
Age: 20,
}
db.Update(func(tx *bolt.Tx) error {
b := tx.Bucket([]byte("person"))
buf, _ := person.Marshal(nil)
fmt.Println(buf, string(buf))
b.Put([]byte(person.Name), buf)
fmt.Printf("Gencode encoded size: %v\n", len(buf))
return nil
})
db.View(func(tx *bolt.Tx) error {
b := tx.Bucket([]byte("person"))
if err := b.ForEach(func(k, v []byte) error {
fmt.Printf("%s is %s.\n", k, v)
p := Person{}
p.Unmarshal(v)
fmt.Println(p)
return nil
}); err != nil {
return err
}
return nil
})
}
输出:
[8 116 101 115 116 110 97 109 101 20]testname
Gencode encoded size: 10
testname istestname.
{testname 20}
因为 gencode 不会写入字段的名字,所以体积很小,正因为如此,用gencode 序列化和反序列化数据时应该注意,数据结构不能动态改变。
项目地址 andyleap/gencode 1
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
算法交易:制胜策略与原理
[美]欧内斯特·陈(Ernest P. Chan) / 高闻酉、黄蕊 / 机械工业出版社 / 49.00
本书是一本引人入胜、信息量大、覆盖各类交易策略的图书。无论个人投资者,还是机构投资者,都可以借鉴和使用其中的策略。本书中的策略大致可分为均值回归系统和动量系统两大类。书中不仅介绍了如何使用每种类别的交易策略,更解释了各种策略之所以有效的原因。本书始终以简单、线性的交易策略为重心,因为复杂的交易策略容易受到过度拟合及数据窥探的侵害。数学和软件是算法交易的两条腿。本书用到了一定程度的数学知识,使其对各......一起来看看 《算法交易:制胜策略与原理》 这本书的介绍吧!
HTML 压缩/解压工具
在线压缩/解压 HTML 代码
SHA 加密
SHA 加密工具