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

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

解決 Go 中循環依賴的最佳實踐

解決 Go 中循環依賴的最佳實踐

Go
慕森卡 2023-06-12 15:51:50
我有一個包含這兩個包的 Go 項目:logging導入config,因為我想將當前配置發送到我的錯誤報告系統config導入logging,因為如果程序無法打開配置文件,我想記錄解決此依賴性錯誤的最佳做法是什么?
查看完整描述

1 回答

?
慕妹3242003

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

您以什么格式將配置發送到錯誤報告系統?也許將其傳遞給日志記錄?比如說,如果它是 json,那么在將其提供給日志記錄之前編組配置,然后[]byte只記錄結果。


但一般來說,如果兩個包直接相互依賴,您可以做的是讓其中一個包聲明一個與另一個包的行為相匹配的接口,然后讓一個單獨的包將具體實例作為接口傳遞。


例如:


/myapp/config


import "myapp/logging"


type Config struct {

     // ...

}


func NewConfig() *Config {

    // ...

    if err != nil {

        logging.LogError(err)

    }

}

/myapp/logging


import "myapp/config"


func LogConfig(c *config.Config) {

    // ...

}


func LogError(err error) {

    // ...

}

因此,在這種情況下,您可以在配置包中聲明一個接口,該接口與日志記錄所需的行為相匹配。


/myapp/config


type Logging interface {

    LogError(error)

}


var logging Logging


func SetLogging(l Logging) {

    logging = l

}


type Config struct {

     // ...

}


func NewConfig() *Config {

    // ...

    if err != nil {

        logging.LogError(err)

    }

}

然后讓日志包中的一個類型通過簡單地委托給原始函數來實現該接口。


/myapp/logging


import "myapp/config"


func LogConfig(c *config.Config) {

    // ...

}


func LogError(err error) {

    // ...

}


type Logging struct{}


func (Logging) LogError(err error) {

    LogError(err)

}

最后還有第三個包使它們一起工作。


/myapp


import "myapp/config"

import "myapp/logging"


func init() {

    config.SetLogging(logging.Logging{})

}


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

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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