分享
  1. 首页
  2. 文章

Go 记录日志——log包

吃一堑消化不良 · · 33399 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

Golang's log模块主要提供了3类接口。分别是 "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]

对于 log.Fatal 接口,会先将日志内容打印到标准输出,接着调用系统的 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 ")
}

有疑问加站长微信联系(非本文作者)

本文来自:开源中国博客

感谢作者:吃一堑消化不良

查看原文:Go 记录日志——log包

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
33399 次点击
被以下专栏收入,发现更多相似内容
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏