亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何在 Go 中設置和訪問“全局”記錄器?

如何在 Go 中設置和訪問“全局”記錄器?

Go
繁星coding 2023-06-05 19:47:48
我確信我遺漏了一些簡單的基本問題,我是新手。假設我不想使用默認記錄器,如何設置記錄器以便它可以在函數之間共享?logissue.gopackage mainimport (  "fmt"  "github.com/pkg/errors"  "log"  "os")var dlog log.Loggerconst logfile string = "killer.log"const logprefix string = "LOGTEST: "func setupLogger(filename, prefix string) (*log.Logger, error) {  out, err := os.OpenFile(filename, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)  if err != nil {    return nil, errors.Wrap(err, "can't open logfile for writing")  }  return log.New(out, prefix, log.LstdFlags), nil}func uselog() error {  fmt.Printf("%T\n", dlog)  dlog.Printf("Hello")            ///// < Here is the issue  return nil}func main() {  dlog, err := setupLogger(logfile, logprefix)  if err != nil {    fmt.Printf("%+v", err)  }  dlog.Printf("test from main")  uselog()}stdoutlog.Loggerpanic: runtime error: invalid memory address or nil pointer dereference[signal SIGSEGV: segmentation violation code=0x1 addr=0x18 pc=0x10970b8]goroutine 1 [running]:log.(*Logger).Output(0x116dd00, 0x2, 0xc000016106, 0x5, 0x0, 0x0)    /usr/local/go/src/log/log.go:172 +0x1e8log.(*Logger).Printf(0x116dd00, 0x10c9202, 0x5, 0x0, 0x0, 0x0)    /usr/local/go/src/log/log.go:179 +0x7emain.uselog(0xc000088050, 0x10ca43b)    /Users/sequoia/learning/Ex_Files_Go_EssT/Exercise Files/logissue.go:25 +0xc4main.main()    /Users/sequoia/learning/Ex_Files_Go_EssT/Exercise Files/logissue.go:35 +0xeeexit status 2killer.logLOGTEST: 2019/02/17 18:25:12 test from main
查看完整描述

2 回答

?
慕尼黑的夜晚無繁華

TA貢獻1864條經驗 獲得超6個贊

因此,首先,根據您上面的代碼,您嘗試設置一個帶有指針記錄器的非指針記錄器,但該指針記錄器不起作用。其次,您在設置 dlog 時使用 := ,它在您的 main 方法中創建一個作用域變量,而不是設置您的全局變量



查看完整回答
反對 回復 2023-06-05
?
江戶川亂折騰

TA貢獻1851條經驗 獲得超5個贊

我試過這個:



import (

    "fmt"

    "github.com/pkg/errors"

    "log"

    "os"

)


const logfile string = "killer.log"

const logprefix string = "LOGTEST: "


var DLog *log.Logger

func setupLogger(filename, prefix string) {

    var err error

    out, err := os.OpenFile(filename, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)

    if err != nil {

        log.Fatal( nil, errors.Wrap(err, "can't open logfile for writing"))

    }

    DLog=log.New(out, prefix, log.LstdFlags)


    fmt.Println("Log object: ",DLog)


}


func uselog() error {

    DLog.Print("Hello") ///// < Here is the issue

    DLog.Print("I have something standard to say")


    fmt.Println("I am done")

    return nil

}


func main() {

    setupLogger(logfile, logprefix)

    DLog.Printf("test from main")

    uselog()

}


查看完整回答
反對 回復 2023-06-05
  • 2 回答
  • 0 關注
  • 158 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號