golang interface转byte_聊聊golang的zap的encoder

本文详细探讨了golang zap库中的Encoder,包括Encoder接口、ObjectEncoder接口、MapObjectEncoder的实现以及jsonEncoder的细节。Encoder接口包含了Clone和EncodeEntry方法,而ObjectEncoder接口提供了多种Add方法。MapObjectEncoder使用map[string]interface{}存储数据,jsonEncoder则涉及到了缓冲和JSON序列化的操作。文章还介绍了Clone方法的工作原理以及EncodeEntry如何构建并返回JSON格式的日志条目。此外,通过实例展示了如何自定义Encoder并注册到zap中。
摘要由CSDN通过智能技术生成

本文主要研究一下golang的zap的encoder

dc15fafa7358d8707992c68d9d3281df.png

encoder

zap@v1.16.0/zapcore/encoder.go

type Encoder interface {    ObjectEncoder    // Clone copies the encoder, ensuring that adding fields to the copy doesn't    // affect the original.    Clone() Encoder    // EncodeEntry encodes an entry and fields, along with any accumulated    // context, into a byte buffer and returns it. Any fields that are empty,    // including fields on the `Entry` type, should be omitted.    EncodeEntry(Entry, []Field) (*buffer.Buffer, error)}

Encoder接口内嵌了ObjectEncoder,定义了Clone、EncodeEntry方法

ObjectEncoder

zap@v1.16.0/zapcore/encoder.go

type ObjectEncoder interface {    // Logging-specific marshalers.    AddArray(key string, marshaler ArrayMarshaler) error    AddObject(key string, marshaler ObjectMarshaler) error    // Built-in types.    AddBinary(key string, value []byte)     // for arbitrary bytes    AddByteString(key string, value []byte) // for UTF-8 encoded bytes    AddBool(key string, value bool)    AddComplex128(key string, value complex128)    AddComplex64(key string, value complex64)    AddDuration(key string, value time.Duration)    AddFloat64(key string, value float64)    AddFloat32(key string, value float32)    AddInt(key string, value int)    AddInt64(key string, value int64)    AddInt32(key string, value int32)    AddInt16(key string, value int16)    AddInt8(key string, value int8)    AddStri
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值