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

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

關閉具有延遲關閉的文件

關閉具有延遲關閉的文件

Go
慕沐林林 2023-07-10 10:07:19
在我的主函數中,我打開一個日志文本文件進行寫入,并使用延遲關閉方法在應用程序退出后將其關閉。但是,在每個新的一天開始時,我希望開始寫入第二天的日志文件,并且我不知道如何關閉前一天的文件并開始寫入當前的文件。在我的主要功能中:func main() {f, err := os.OpenFile("2019-07-24.txt", os.O_RDWR | os.O_CREATE | os.O_APPEND, 0644)    if err != nil {        log.Fatalf("Error opening log file: %v", err)    }    defer f.Close()    log.SetOutput(f)}現在,當我在新的一天收到另一個包裹中的消息時:func gateway() {f, err := os.OpenFile("2019-07-25.txt", os.O_RDWR | os.O_CREATE | os.O_APPEND, 0644)    if err != nil {        log.Fatalf("Error opening log file: %v", err)    }    defer f.Close()    log.SetOutput(f)}如何從另一個包獲取指向前一天日志文件的指針,然后將其關閉(除非應用程序完全關閉,否則不會調用延遲調用?
查看完整描述

1 回答

?
翻過高山走不出你

TA貢獻1875條經驗 獲得超3個贊

創建一個管理日志輸出的包。


package logoutput


package main


import (

    "io"

    "log"

    "sync"

)


var (

    mu            sync.Mutex

    curr io.WriteCloser

)


func Set(w io.WriteCloser) {

    mu.Lock()

    defer mu.Unlock()

    prev := curr

    curr = w

    log.SetOutput(curr)

    if prev != nil {

       prev.Close()

    }

}


func Close() {

    mu.Lock()

    defer mu.Unlock()

    log.SetOutput(os.Stderr) // revert to default

    if curr != nil {

       curr.Close()

    }

    curr = nil

}

從 main 和 gateway 包中調用該包。


f, err := os.OpenFile("2019-07-24.txt", os.O_RDWR | os.O_CREATE | os.O_APPEND, 0644)

if err != nil {

    log.Fatalf("Error opening log file: %v", err)

}

logoutput.Set(f)

defer logoutput.Close() // call from main only


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

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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