logging - setflags - logrus vs glog



为什么我应该使用log.Println而不是fmt.Println? (1)

有两件事是不同的:

  1. 通过包日志打印对于并发goroutine是安全的(普通的fmt不是)

  2. 日志可以自动添加计时信息。

所以这些是完全不同的两件事。 log用于记录, fmt用于格式化。 (好吧,日志使用相同的动词和标志,但这很方便)。

log.go (日志包的实现):

167 // Println calls l.Output to print to the logger.
168 // Arguments are handled in the manner of fmt.Println.
169 func (l *Logger) Println(v ...interface{}) { l.Output(2, fmt.Sprintln(v...)) }

log.Println只是log.Println的函数包装器,我为什么要使用它而不是fmt.Printlnfmt.Sprintln

任何实际的原因?





go