代码拉取完成,页面将自动刷新
package log
import (
"fmt"
"log"
"os"
"runtime"
)
func Init() {
logSingleton.Logger = log.New(os.Stdout, "Test:", log.LstdFlags)
}
var logSingleton ServiceProviderLogger
type ServiceProviderLogger struct {
*log.Logger
}
func defaultLogger() *log.Logger {
if nil == logSingleton.Logger {
Init()
}
return logSingleton.Logger
}
func NewLogger(logger *log.Logger) {
logSingleton.Logger = logger
}
func logHeader(format string) string {
pc, _, lineNo, ok := runtime.Caller(2)
if !ok {
return ""
}
return fmt.Sprintf("func:%s:%d [%s]",
runtime.FuncForPC(pc).Name(), lineNo, format)
}
func logHeaderB(args ...any) string {
pc, _, lineNo, ok := runtime.Caller(2)
if !ok {
return ""
}
return fmt.Sprintf("func:%s:%d [%s]",
runtime.FuncForPC(pc).Name(), lineNo, args)
}
func Tracef(format string, args ...any) {
defaultLogger().Printf(logHeader("[Trace]:["+format+"]"), args...)
}
func Debug(format string) {
defaultLogger().Printf(logHeaderB("[Debug]:[%s]"), format)
}
func Debugf(format string, args ...any) {
defaultLogger().Printf(logHeader("[Debug]:["+format+"]"), args...)
}
func Infof(format string, args ...any) {
defaultLogger().Printf(logHeader("[Info]:["+format+"]"), args...)
}
func Warnf(format string, args ...any) {
defaultLogger().Printf(logHeader("[Warn]:["+format+"]"), args...)
}
func Errorf(format string, args ...any) {
defaultLogger().Printf(logHeader("[Error]:"+format+"]"), args...)
}
func Fatalf(format string, args ...any) {
defaultLogger().Fatalf(logHeader("[Fatal]:"+format+"]"), args...)
}
func Info(args ...any) {
defaultLogger().Print(logHeader("[Info]:[" + fmt.Sprint(args...) + "]"))
}
func Error(args ...any) {
defaultLogger().Print(logHeader("[Error]:[" + fmt.Sprint(args...) + "]"))
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。