//log.go in package log// 每种格式占据一个bit,所以可以通过|设置格式const(
Ldate =1<<iota// the date in the local time zone: 2009/01/23
Ltime // the time in the local time zone: 01:23:23
Lmicroseconds // microsecond resolution: 01:23:23.123123. assumes Ltime.
Llongfile // full file name and line number: /a/b/c/d.go:23
Lshortfile // final file name element and line number: d.go:23. overrides Llongfile
LUTC // if Ldate or Ltime is set, use UTC rather than the local time zone
LstdFlags = Ldate | Ltime // initial values for the standard logger)// 日志变量类型// 互斥锁保证多个goroutine的线程安全type Logger struct{
mu sync.Mutex // ensures atomic writes; protects the following fields
prefix string// prefix to write at beginning of each line
flag int// properties
out io.Writer // destination for output
buf []byte// for accumulating text to write}// 全局变量var std =New(os.Stderr,"", LstdFlags)// 标准日志命令是通过std调用的funcPrintln(v ...interface{}){
std.Output(2, fmt.Sprintln(v...))}