Go 记录日志——log包

news/2024/11/29 8:57:47/

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

package mainimport ("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 mainimport ("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 mainimport ("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 ")
}

http://www.ppmy.cn/news/859774.html

相关文章

视频“高清”与“标清”技术标准区别

“高清”的定义&#xff0c;主要通过两个条件进行判断&#xff1a;一是原始画面比例需为16:9&#xff0c;传统4:3比例不能算“高清”&#xff1b;二是图像垂直方向的清晰度要达到720线以上&#xff0c;即只有720p、1080i和1080p的信号画面才能够称为“高清”&#xff0c;而像48…

UE4 如何做视屏清晰度(超清、高清、清晰、流畅)

创建Media Player&#xff0c;然后创建Media Texture 通过Media Texture创建Material 创建一个Render Target 再播放视屏的UI里面把视屏的Material画在Render Target内 最后将Render Target再生成其材质 将Render Target生成的材质放在UI内部 现在在Render Target内部就可以修…

高清标清区别

&#xff08;1&#xff09;从技术上来说。按技术划分&#xff0c;电视可分为模拟电视和数字电视。数字电视又可分为高清电视&#xff08;HDTV&#xff09;和标清电视(SDTV)等。传统(模拟)电视有三大电视制式&#xff1a;NTSC制、PAL制和SECAM制。高清电视也有很多种格式&#x…

【Linux】初步理解操作系统和进程概念

一.认识操作系统 操作系统是一款纯正的 “搞管理” 的文件。 那操作系统为什么要管理文件&#xff1f; “管理” 又是什么&#xff1f; 它是怎么管理的&#xff1f; 为什么&#xff1f; 1.操作系统帮助用户&#xff0c;管理好底层的软硬件资源&#xff1b; 2.为了给用户提供一个…

C. Vampiric Powers, anyone? - 思维+前缀和

分析&#xff1a; 添加新元素的操作可以理解为添加任意一段以n结尾的异或和&#xff0c;当原数组总异或和与新加的元素进行异或又可以得到剩余的前缀的异或和&#xff0c;假设新加的元素的值是i到n的异或和x&#xff0c;那么总异或和sumpre^x&#xff0c;所以sum^xpre&#xff…

Github 热度飙升,一键生成最近抖音超火的 AI 人物绘图

点击关注公众号&#xff0c;利用碎片时间学习 Paper2GUI 是一款面向普通人的 AI 桌面 APP 工具箱&#xff0c;免安装即开即用&#xff0c;已支持20AI 模型&#xff0c;内容涵盖语音合成、视频补帧、视频超分、目标检测、图片风格化、OCR 识别等领域。支持 Windows、Mac、Linux …

iOS热修复 JSPatch

JSPatch使用小记 hotfix的作用众所周知&#xff0c;Android和iOS都有各自的技术&#xff0c;但是相比Android的当天发布来说&#xff08;如果你们的项目不需要灰度&#xff09;&#xff0c;iOS热更新的意义更加重大。因为iOS审核周期长不说&#xff0c;而且运气不好会遇到各种…

iPhone因安全漏洞上热搜,苹果:暂时无法修复,法国总统也中招

????????关注后回复 “进群” &#xff0c;拉你进程序员交流群???????? 明敏 发自 凹非寺量子位 报道 | 公众号 QbitAI iPhone又双叒被曝存在安全隐患了。 只要发送钓鱼链接&#xff0c;无论你点不点击&#xff0c;你的信息都可以被窃取&#xff0c;甚至连麦克…