log
2022年10月20日大约 2 分钟
log
Go 语言标准库 log 包实现了简单的日志。
func main() {
log.Println("日志")
log.Panicln("panic日志")
log.Fatalln("错误日志")
}
Fatal 会在写入日志信息后调用os.exit(1)
,panic 则会抛出panic
前缀
func (l *Logger) Prefix() string //获取前缀
func (l *Logger) SetPrefix(prefix string) //设置前缀
例子
func main() {
log.SetPrefix("[main]")
log.Println("日志")
log.Panicln("panic日志")
}
Flag
方法
func (l *Logger) Flags() int //访问
func (l *Logger) SetFlags(flag int) //设置
常量
const (
Ldate = 1 << iota // 日期
Ltime // 时间
Lmicroseconds // 微秒
Llongfile // 完成文件名称
Lshortfile // 短文件名称
LUTC // 时区
Lmsgprefix // 前缀
LstdFlags = Ldate | Ltime // 初始值
)
例子
func main() {
log.SetFlags(log.Lshortfile | log.Lmicroseconds | log.Lmsgprefix | log.Ldate | log.Ltime)
log.Println("日志")
log.Panicln("panic日志")
}
当然也可以使用log.SetOutput(w io.Writer)
来设置日志的输出路径,也可以通过New
方法创建自己的实例。
func New(out io.Writer, prefix string, flag int) *Logger
总而言之,标准库的log
包提供的功能并不够完善,我们通常会使用更加完善的第三方日志包,例如zap
等等。