gencodec工具

本文介绍了gocodec,一个用于自动生成Go语言类型封送处理代码的工具。通过指定类型、样式、字段覆盖和输出文件,用户可以便捷地生成json、yaml、toml等格式的封送代码。字段覆盖允许在封送处理时使用不同类型的字段,并支持特定转换规则。gocodec简化了封送和解封送过程,提高了开发效率。
摘要由CSDN通过智能技术生成

gencodec

百度了一下,居然找不到gencodec工具的中文使用介绍,对我这种拿来主义的人真有点不适应,简单总结一下介绍使用。

gencodec是一个非常便捷的通过类型自动生成marshaling代码的工具,工具的安装就不细说了,基本没有使用其他库除了golang.org/x里某些库,地址:https://github.com/fjl/gencodec。

使用方式:

gencodec -type MyType -field-override MyTypeMarshaling -formats json,yaml,toml -out mytype_json.go

在相应的包下指定:

  • type: 需要生成的类型名
  • formats: 样式,支持三种json,yaml,toml,默认json
  • field-override: (可选)覆盖类型
  • out: 生成的文件

类型

type foo struct {
	Required string `gencodec:"required"`    //unmarshaling时需要检查该字段是否存在
	Optional string                         // 文件中字段以原名标识
	Renamed  string `json:"otherName"`      //封送到相应样式文件中的字段名 
}

字段覆盖

type foo struct {
	Field        string
	SpecialField string
}

func (f foo) Func() string {
    return f.Field + "-" + f.SpecialField
}

type fooMarshaling struct {
	SpecialField specialString // overrides type of SpecialField when marshaling/unmarshaling
	Func string `json:"id"`    // adds the result of foo.Func() to the serialised object under the key id
}

gencodec的调用可以指定一个额外的“字段覆盖”结构,从中进行封送处理类型替换。如果覆盖结构体中字段名称与原结构体中字段匹配,则生成的封送处理方法将使用覆盖的类型并与原始字段类型进行转换。如果覆盖结构体中字段名称与原结构体中字段不匹配,但有与原结构体中的同名且无参数的方法,并且该方法的返回值与字段类型相同,则Marshal*调用该方法。如果有匹配的方法F,但是返回类型或参数不合适,就会引发错误;unmarshaling时该字段无意义。

type specialString string

func (s *specialString) UnmarshalJSON(input []byte) error { ... }

type Foo struct{ S string }

type fooMarshaling struct{ S specialString }

// 被自动转换为
func (f *Foo) UnmarshalJSON(input []byte) error {
	var dec struct{ S *specialString }
	...
	f.S = string(dec.specialString)   // 直接类型转换
	...
}

覆盖结构体中的字段类型必须可以简单地转换为原始字段类型。gencodec支持以下转换:

  • 如果字段是可直接分配的,则不会发出转换。
  • 如果字段可以根据Go语言规则进行转换,则会发出一个简单的转换。
    如上,覆盖结构体fooMarshaling.S的类型specialString可直接转成string,即使specialString实现了UnmarshalJSON,也不会在gencodec的unmarshaling中嵌套调用,而是直接转换。

参考:

https://godoc.org/github.com/fjl/gencodec

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值