草庐IT

log_error

全部标签

go - Q : Getting Build Error "Invalid Import Path"

我坚持使用它说的“beerun”来运行BeeGO应用程序问题是我已经正确设置了我的GOPATH到D:/WebDev/GO/BeeGO/test-project/并且路由器路径确实存在,我已尝试手动构建文件,但它不会生成.exe文件。有人知道如何解决这个问题吗?我使用的是Windows8.1Pro(64位)谢谢 最佳答案 GO期望$GOPATH下的目录结构按照codeorganization中描述的以下方式:$GOPATH/src与其将源文件直接放在$GOPATH下(D:/WebDev/GO/BeeGO/test-project/对于

golang代码组织: where should I put custom error types that are only relevant to one function?

我刚刚开始处理我的第一个golang项目,非常喜欢从函数返回自定义错误类型并在调用代码中使用类型断言来检查特定错误的想法。我发现这个解决方案比总是比较错误消息更清晰。我唯一的问题是:您最好将这些自定义错误类型放在哪里?假设许多自定义错误类型仅由一个实用程序函数使用(返回),它们应该与函数放在同一个包中吗?我应该以某种方式将它们分组吗?或者也许有更好的方法来做这种事情.. 最佳答案 “相同的包裹”是我最初的想法。在某些情况下,将它们放在不同的包中是有意义的,但只有当它们从多个包中的函数中合法地出现“相同的错误”时,并且这些包都不是逻辑

logging - Golang 日志记录策略

与Python中的logging标准库不同,Go中的标准log包不支持级别。许多包求助于第三方日志包,例如glog或logrus。当导入可能使用或不使用第三方日志包的第三方包时,Go的最佳日志记录策略是什么。 最佳答案 所以,我想你是在问,如果我正在使用的包使用普通的旧https://golang.org/pkg/log/怎么办?我的主包使用了一些特殊的东西,比如log.Info、log.Warn、log.Error和log.Debug?如果包向您公开了log.Logger对象,您可以使用SetFlags、SetOutput、Set

logging - 在 Golang 中实现一个最小的记录器

我在Golang中创建了一个最小的记录器。我试图让它尽可能简单,但出现了两个问题:消息字符串显示为括号[]中的数组使用log.Lshortfile标志的文件名始终显示为logger.go这是我的代码:packageloggerimport("log""os")var(dlog=log.New(os.Stdout,"\x1B[36mDEBUG:\x1B[0m",log.Ldate|log.Ltime|log.Lshortfile)wlog=log.New(os.Stdout,"\x1B[35mWARN:\x1B[0m",log.Ldate|log.Ltime|log.Lshortfile

go - 为什么返回一个实现了error接口(interface)的类型会自动调用Error()方法?

链接:https://play.golang.org/p/z50pUnAe4qpackagemainimport("fmt""time")typeMyErrorstruct{Whentime.TimeWhatstring}func(e*MyError)Error()string{returnfmt.Sprintf("at%v,%s",e.When,e.What)}funcrun()error{return&MyError{time.Now(),"itdidn'twork",}}funcmain(){iferr:=run();err!=nil{fmt.Println(err)}}我知道内

logging - Golang 包和跨包使用变量

所以我有点想知道这里的最佳实践是什么。我有一个包含多个子包的应用程序,有些需要访问主包中的记录器,因为我使用带有颜色和时间戳等的自定义记录器。是通过像这样注入(inject)它来实现这一目标的唯一方法吗?(假设Handler在一个名为command的子包中)typeHandlerstruct{loggerlogging.Logger}funcNewHandler(loggerlogging.Logger)Handler{returnHandler{logger:logger,}}handler:=command.NewHandler(logger)我遇到的这个问题是测试变得很烦人,因为

高语 : "No common algorithm for key exchange" error

我是GoLang的新手,我正在尝试使用go连接到远程服务器。但是我不断收到以下错误Failedtodial:ssh:handshakefailed:ssh:nocommonalgorithmforkeyexchange;clientoffered:[curve2****-sh****@libssh.org****-sha*-nis****ecdh-sha2-nistp384ecdh-sha2-nistp****diffie-hellman-group14-sha1diffie-hellman-group1-sha1],serveroffered:[diffie-hellman-grou

http - 使用go http client Do方法时,httpResponse和error不能同时为nil吗?

在officialdocumentation中可见以及几乎其他网上的任何地方,处理http客户端错误的常见模式如下:req,err:=http.NewRequest("GET","http://example.com",nil)req.Header.Add("If-None-Match",`W/"wyzzy"`)resp,err:=client.Do(req)iferr!=nil{//handleerror}deferresp.Body.Close()阅读有关http客户端方法的文档,我无法理解是否可以同时接收resp和err不是nil,如果我们考虑一下Do方法文档中写的内容,这似乎是

logging - Golang 日志函数返回参数

我想记录一个函数的返回值。我能想到的“最聪明”的事情是将我的实际函数体包装在一个闭包中。funcfoo(aint,bint)(int,error){c,err:=func(aint,bint)(int,error){//...returnc,err}(a,b)fmt.Printf("%v%v%v%v",a,b,c,err)returnc,err}有没有一种方法可以用更少的样板文件来实现这一点? 最佳答案 也许我误解了你的问题,但是:packagemainimport("log")funcfoo(a,bint)(cint,errerr

java - 使用 SimpleDateFormat 解析 svn log -xml 日期输出

svnlog命令的xml输出的日期格式如下。2014-04-24T08:51:58.213757Z我尝试使用带有以下字符串的SimpleDateFormat将其解析为util.Date对象。yyyy-MM-ddTHH:mm:ss.SSSSSSZ完整方法protectedDateformatDate(StringdateString){//2014-04-24T08:51:58.213757ZDateFormatformat=newSimpleDateFormat("yyyy-MM-ddTHH:mm:ss.SSS");format.setTimeZone(TimeZone.getTime