duangan6731 2018-06-25 03:19
浏览 155

如何在go包中使用常量

I'm writing my first go code and I'm trying to convince myself what I'm doing is not wrong.

anyway, here the project the tree structure.

.
├── helpers
│   └── common.go
├── logger
│   └── util.go
├── logger_example
└── runner.go

The main file to look over here is logger/util.go which look like this.

package logger

import (
  "log"
  "os"
)

type Logger struct {
  *log.Logger
}

func (l *Logger) Info(v ...interface{}) {
  l.SetPrefix("Info: ")
  l.Println(v...)
}

func (l *Logger) Error(v ...interface{}) {
  l.SetPrefix("Error: ")
  l.Println(v...)
}

func (l *Logger) Warn(v ...interface{}) {
  l.SetPrefix("Warn: ")
  l.Println(v...)
}

func (l *Logger) Debug(v ...interface{}) {
  l.SetPrefix("Debug: ")
  l.Println(v...)
}



func NewLogger() *Logger {
  logger := log.New(os.Stdout, "", log.Ldate|log.Ltime|log.Lshortfile)
  return &Logger{logger}
}

As you all can see, I'm just setting the prefix to "INFO | WARN | ERROR | DEBUG"

On the main package I have safely created a Logger instance and VOILA it worked.

Only until I decided to add a helpers package and now things do not look the way I wanted.

since the logger.Logger instance created inside main package, I have to pass it reference to every since package function where I want to invoke the logger statement. (see the below example ..)

// dodly_logger/logger/common.go
package helpers

import "dodly_logger/logger"
func Display(dodlyLogger *logger.Logger) {
  dodlyLogger.Info("Inside a helper package")
}

The Main package..

package main

import (
  logger "dodly_logger/logger"
  helpers "dodly_logger/helpers"
)

func main() {
  dodlyLogger := logger.NewLogger()
  dodlyLogger.Info("INFO MESSAGE")
  dodlyLogger.Error("ERROR MESSAGE")
  // Ehh, I have to pass the dodlyLogger ..
  helpers.Display(dodlyLogger)
}

Ok, now I know my GOLang knowledge is not complete hence I'm hoping people over here can point me how can I write this more clinically wherein I do not have to pass the reference of the logger.Logger to every function for which I need to log.

  • 写回答

1条回答 默认 最新

  • dongshubang7816 2018-06-25 03:38
    关注

    Create a package level variable with var.

    package main

    import (
        logger "dodly_logger/logger"
        helpers "dodly_logger/helpers"
    )
    
    var dlogger logger.Logger
    
    func init() {
        dlogger = logger.NewLogger()
    }
    
    func main() {
        dlogger.Info("Starting Main")
        a()
    }
    
    func a() {
        dlogger.Info("in a")
    }
    
    评论

报告相同问题?

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度