log标准库的使用

log库的使用

package main

import (
	"fmt"
	"log"
	"os"
	"path"
	"runtime"
	"time"
)

//runtime.Caller(),处理err问题
func rc(err error) {
	if err != nil {
		pc, file, line, ok := runtime.Caller(1) //表示调用的层数,0 是他本身,1 是谁调用的他 2 再往上找一层
		if !ok {
			fmt.Printf("runtime.Caller() failed\n")
			return
		}
		funcName := runtime.FuncForPC(pc).Name()
		fmt.Printf("funcName:%s, file:%s, line:%d, cont:%s", funcName, path.Base(file), line, err)
	}
}

func main() {
	fileObj, err := os.OpenFile("./xx.log", os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
	rc(err)              //funcName: main.main,file:main.go, line:25,cont:open ./xx.log: no such file or directory<nil>
	fmt.Println(fileObj) //文件句柄,也就是文件的指针
	log.SetOutput(fileObj)
	for {
		log.Println("这是一条测试的日志")
		time.Sleep(time.Second * 3)
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值