代码拉取完成,页面将自动刷新
package entry
import (
"sync"
"sync/atomic"
"time"
"gitee.com/leminewx/loggo/field"
"gitee.com/leminewx/loggo/level"
)
var (
once sync.Once
pool *sync.Pool
)
func init() {
once.Do(func() {
pool = &sync.Pool{New: func() interface{} { return &Entry{Fields: nil} }}
})
}
// Entry 定义日志条目的数据结构
type Entry struct {
call int32 // 调用计数
Level level.Level // 日志等级
Time time.Time // 触发时间
Message string // 日志内容
Fields []field.Field // 补充字段
}
// New 新建一条日志
func New(call int32, level level.Level, msg string, fields ...field.Field) *Entry {
entry := pool.Get().(*Entry)
entry.call = call
entry.Level = level
entry.Time = time.Now()
entry.Message = msg
entry.Fields = fields
return entry
}
// Dealloc 回收 Entry,以备复用
func (own *Entry) Dealloc() {
if atomic.AddInt32(&own.call, -1) < 1 {
own.call = 0
own.Message = ""
own.Fields = nil
pool.Put(own)
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。