一、log日志包

log支持并发操作。其结构定义如下



1type Logger struct {
2 mu sync.Mutex // ensures atomic writes; protects the following fields
3 prefix string // prefix to write at beginning of each line // ⽇志⾏前缀
4 flag int // properties // ⽇志打印格式标志,⽤于指定每⾏⽇志的打印格式
5 out io.Writer // destination for output // ⽤于指定⽇志输出位置,理论上可以是任务地⽅,只要实现了io.Writer接⼝就⾏
6 buf []byte // for accumulating text to write // ⽇志内容
7}


log基本日志格式



1Ldate       = 1 << iota     //  形如  2009/01/23  的⽇期
2Ltime // 形如 01:23:23 的时间
3Lmicroseconds // 形如 01:23:23.123123 的时间
4Llongfile // 全路径⽂件名和⾏号: /a/b/c/d.go:23
5Lshortfile // ⽂件名和⾏号: d.go:23
6LstdFlags = Ldate | Ltime // ⽇期和时间


(1)Golang's log模块主要提供了3类接口。分别是 “Print 、Panic 、Fatal ”,对每一类接口其提供了3中调用方式,分别是 "Xxxx 、Xxxxln 、Xxxxf",基本和fmt中的相关函数类似。

• log.Print:打印日志,和fmt.包没什么区别,只是加上了上面的日志格式

• log.Fatal :,会先将日志内容打印到标准输出,接着调用系统的os.exit(1) 接口,退出程序并返回状态 1 。但是有一点需要注意,由于是直接调用系统接口退出,defer函数不会被调用。

• log.Panic:该函数把日志内容刷到标准错误后调用 panic 函数,

 

Demo



package main

import (
"fmt"
"log"
)

//fatal
func testDeferfatal() {
defer func() {
fmt.Println("--first--")
}()
log.Fatalln("test for defer Fatal")
}

//panic
func testDeferpanic() {
defer func() {
fmt.Println("--first--")
if err := recover(); err != nil {
fmt.Println(err)
}
}()
log.Panicln("test for defer Panic")
defer func() {
fmt.Println("--second--")
}()

}
func main() {
arr := []int{2, 3}

log.Print("Print array ", arr, "\n")
log.Println("Println array", arr)
log.Printf("Printf array with item [%d,%d]\n", arr[0], arr[1])

testDeferpanic()

//testDeferfatal()
}


(2)你也可以自定义Logger类型

log.Logger提供了一个New方法用来创建对象

函数原型



func New(out io.Writer, prefix string, flag int) *Logger


①输出位置out,是一个io.Writer对象,该对象可以是一个文件也可以是实现了该接口的对象。通常我们可以用这个来指定日志输出到哪个文件

②prefix 我们在前面已经看到,就是在日志内容前面的东西。我们可以将其置为 "[Info]" 、 "[Warning]"等来帮助区分日志级别。

③flags 是一个选项,显示日志开头的东西,可选的值见前面所述

 

Demo



import (
"log"
"os"
)

func main() {
fileName := "Info_First.log" //路径+文件名
logFile, err := os.Create(fileName)
defer logFile.Close()
if err != nil {
log.Fatalln("open file error")
}
debugLog := log.New(logFile, "[Info]", log.Llongfile)
debugLog.Println("A Info message here")
debugLog.SetPrefix("[Debug]")
debugLog.Println("A Debug Message here ")
}