草庐IT

go-mocket

全部标签

go - 如何将字符串转换为 JSON obj?

这个问题在这里已经有了答案:DecodeJSONwithunknownstructure(2个答案)关闭3年前。下面是我试过但无济于事的代码:jsonObj,err:=json.Marshal(supportJSONString)iferr!=nil{http.Error(w,err.Error(),http.StatusInternalServerError)}fmt.Fprintf(w,"%s",jsonObj)

go - 调用提升函数时出现未定义错误

在GO中使用提升的函数时出现undefined错误。import"log"typeloggerstruct{log.Logger}logError:=logger.New(os.Stderr,"ERROR",log.LstdFlags)logOut:=logger.New(os.Stdout,"INFO",log.LstdFlags)这会导致编译器错误:logger.go:logger.Newundefined(typeloggerhasnomethodNew)但是,New是log.Logger的升级功能。这里有什么问题? 最佳答案

go - 在单个项目中使用不同版本的 go 包

我正在尝试在一个项目中使用单个go工具的多个版本。例如,这里有一个包裹:https://godoc.org/github.com/docker/docker/pkg,现在这个包有一些目录在旧版本中可用,但在当前版本中不可用,反之亦然。我想同时使用两者,goget始终获取最新版本。如果我切换到旧版本,我会错过最新的目录。知道如何保留这两个版本吗?TIA。 最佳答案 在gopkg.in的帮助下,如果新旧版本的主要版本不同,您可以使用不同的导入路径导入:https://gopkg.in/go-redis/redis.v2https://g

go - 如何等待 panic 的协程?

等待goroutine的常见方法是使用*sync.WaitGroup:funcmain(){wg:=&sync.WaitGroup{}wg.Add(1)gofunc(){deferwg.Done()//Longrunningtask}()wg.Wait()}这里没有问题。但是,这个怎么样:funcmain(){wg:=&sync.WaitGroup{}wg.Add(1)gofunc(){deferwg.Done()//Longrunningtaskpanic("Somethingunexpectedhappened.")}()wg.Wait()}在这种情况下,当wg.Done()被调用

go - "selective"goroutines 互斥

我是Go的新手,我想实现一个自定义的互斥机制,每个应用程序用户一次可以执行一个goroutine。为简化起见,将U1和U2视为应用程序用户以及F1(userId)、F2(userId)和F3(userId)三个不同的goroutine,它们从数据库读取/写入记录仅与给定用户相关.我希望,如果U1调用(F1、F2、F3)、(F2、F3)在F1结束之前不执行,那么执行F2或F3(按调用顺序将是最佳解决方案),最后剩下的被执行。U2不受U1锁的影响,但如前所述,她由自己的锁控制。你将如何实现?有内置的原语吗?谢谢 最佳答案 使用sync.

带指针的 Go 工厂方法多态性

typeFoointerface{FooMethod()}typeBarFoostruct{}func(f*BarFoo)FooMethod(){}funcNewBarFoo()*Foo{return&BarFoo{}}错误:不能使用“&BarFoo{}”(类型*BarFoo)作为类型*Foo为什么我会收到此类代码的编译错误?多态性是否适用于指针?顺便说一句,这段代码没问题funcNewBarFoo()Foo{return&BarFoo{}} 最佳答案 您只需将函数签名更改为funcNewBarFoo()Foo{return&Bar

go - 从 Go 中的另一个嵌套结构变量访问结构的变量

给出了我编写的2个结构。typeDNSPacketstruct{headerDNSHeader.DNSHeaderquestions[]DNSQuestion.DNSQuestionanswers[]DNSRecord.DNSRecordauthorities[]DNSRecord.DNSRecordresources[]DNSRecord.DNSRecord}typeDNSHeaderstruct{iduint16//16bitsrecursion_desiredbool//1bittruncated_messagebool//1bitauthoritative_answerbool

go - 在 Go 中使用 stdlib 中未导出的函数/类型

免责声明:是的,我知道这不是“应该做的”、“使用接口(interface)组合和委托(delegate)”以及“语言的作者更清楚”。然而,我面临着从标准库中复制粘贴并创建我自己的包,或者按照我的要求做的选择。所以请不要回复“你想做的是错误的,你是一个糟糕的开发者,你应该感到难过。”因此,在Go中我们有httpstdlib包。这个包有许多处理HTTPRangeheader和响应的函数(解析器,“偏移量+大小”的结构等等)。出于各种原因,我想使用与ServeContent非常相似但工作方式略有不同的东西(长话短说-执行ReaderAt体操所需的管道数量不是最优的对于我想要完成的事情)所以我

go - go 是否有允许的函数返回的最大数量

使用golang的多次返回功能,是否有返回次数限制?或者假设内存大小不是问题,用户是否可以假设函数有数百万次返回。 最佳答案 理论上没有限制。https://golang.org/ref/spec#ExpressionList当然,在实践中,它有时会失败。1000个输出参数:https://play.golang.org/p/pOf4YCahtER在我的电脑上,我能够使用Go1.11.5将其推送到8190个输出参数。输出列表是一系列i(typeiint),返回语句包含一系列0。将类型名称更改为ii降低了我能够达到的最大值。这表明限制

go - 从不同的 go 例程将数据写入同一 channel ,无需 WaitGroup 即可正常工作

在等待wg.Wait()后,当使用多个带WaitGroup的go例程将数据写入同一channel时,出现异常,表示所有go例程都处于休眠状态或锁死状态。packagemainimport("fmt""runtime""sync")varwgsync.WaitGroupfuncCreateMultipleRoutines(){ch:=make(chanint)fori:=0;i当尝试在没有WaitGroup的情况下实现这一点时,我能够通过循环将数据推送到channel的确切次数从channel读取数据,但我无法调整范围,因为当我们关闭channel时会出现panic。这是示例代码pack