Go 記錄日志——log包
吃一塹消化不良
Print 、Panic 、Fatal ”,對每一類接口其提供了3中調用方式,分别是 "Xxxx 、 Xxxxln 、Xxxxf",基本和fmt中的相關函數類似,下面是一個Print的示例:
package main
import (
"log"
)
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])
}
會得到如下結果:
2016/12/15 19:46:19 Print array [2 3]
2016/12/15 19:46:19 Println array [2 3]
2016/12/15 19:46:19 Printf array with item [2,3]
os.exit(1) 接口,退出程式并傳回狀态 1 。但是有一點需要注意,由于是直接調用系統接口退出,defer函數不會被調用,下面是一個Fatal的示例:
package main
import (
"fmt"
"log"
)
func test_deferfatal(){
defer func() {
fmt.Println("--first--")
}()
log.Fatalln("test for defer Fatal")
}
func main() {
test_deferfatal()
}
會得到如下結果:
2016/12/15 19:46:45 test for defer Fatal
可以看到并沒有調用defer 函數。
對于log.Panic接口,該函數把日志内容刷到标準錯誤後調用 panic 函數,下面是一個Panic的示例:
package main
import (
"fmt"
"log"
)
func test_deferpanic(){
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() {
test_deferpanic()
}
會得到如下結果:
2016/12/15 19:59:30 test for defer Panic
--first--
test for defer Panic
可以看到首先輸出了“test for defer Panic”,然後第一個defer函數被調用了并輸出了“--first--”,但是第二個defer 函數并沒有輸出,可見在Panic之後聲明的defer是不會執行的。
你也可以自定義Logger類型, log.Logger提供了一個New方法用來建立對象:
func New(out io.Writer, prefix string, flag int) *Logger
該函數一共有三個參數:
(1)輸出位置out,是一個io.Writer對象,該對象可以是一個檔案也可以是實作了該接口的對象。通常我們可以用這個來指定日志輸出到哪個檔案。
(2)prefix 我們在前面已經看到,就是在日志内容前面的東西。我們可以将其置為 "[Info]" 、 "[Warning]"等來幫助區分日志級别。
(3) flags 是一個選項,顯示日志開頭的東西,可選的值有:
Ldate = 1 << iota // 形如 2009/01/23 的日期
Ltime // 形如 01:23:23 的時間
Lmicroseconds // 形如 01:23:23.123123 的時間
Llongfile // 全路徑檔案名和行号: /a/b/c/d.go:23
Lshortfile // 檔案名和行号: d.go:23
LstdFlags = Ldate | Ltime // 日期和時間
示例如下:
package main
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 ")
}