草庐IT

std-call-once

全部标签

go - 我使用 pprof 的 golang 程序分析显示内存在 std/json 包中的 json (* decodeState) objectInterface 处增加

我有一个golang程序,它使用std“encoding/json”包中的unmarshall,其大小不断增加(内存泄漏)。使用pprof的内存配置文件图显示内存在json(*decodeState)objectInterface增加。我想了解解决问题的方式和原因。我已经在上层尝试了几件事,比如释放返回值以避免泄漏,但没有成功。func(jJSONEncoding)From(b[]byte,msginterface{})(interface{},error){err:=json.Unmarshal(b,&msg)returnmsg,err}pproftop5显示了这个调用,以及下面的详

elasticsearch - 戈朗错误 "not enough arguments in call"

我刚接触golang。尝试通过golang实现批量上传到Elasticsearch。我正在使用golang库->https://github.com/olivere/elastic用于与Elasticsearch通信。此外,我正在尝试一段示例代码,但出现以下错误...suresh@BLR-245:~/Desktop/tools/golang/src$goinstallgithub.com/crazyheart/elastic-bulk-upload#github.com/crazyheart/elastic-bulk-uploadgithub.com/crazyheart/elasti

unit-testing - 错误 : suite. go:61: test paniced: reflect: Call with too few input arguments

我正在golang中设置单元测试。但是现在我在运行gotest-v时遇到错误。我想解决这个错误并使测试成功。article├client├api│├main.go│├contoroller││├contoroller.go││└contoroller_test.go│├service││├service.go││└service_test.go│├dao││├dao.go││└dao_test.go│├s3││├s3.go││└s3_test.go│├go.mod│├go.sum│└Dockerfile├nginx└docker-compose.yml现在我正在为service.go设

go - sync.Once.Do 是否保证跨 goroutine 的可见性?

例子here暗示sync.Once.Do保证字符串vara跨goroutines的可见性。如果例如由sync.Once.Do调用的函数f()初始化结构实例的多个字段,是否也是如此?在没有任何额外同步的情况下,结构实例的所有字段是否对其他goroutine可见? 最佳答案 让我们分解一下example:变量a在函数setup()返回之前设置,因为在单个goroutine中的读取和写入必须表现得好像它们已执行按照程序指定的顺序[1].once.Do()对setup()的单次调用发生在once.Do()的任何调用之前返回[2].因此,a变

go - 如何解决golang中 "missing Location in call to Date"的错误

关闭。这个问题是notreproducibleorwascausedbytypos.它目前不接受答案。这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topic在这里,这个问题的解决方式不太可能帮助future的读者。关闭4年前。Improvethisquestion我写了一个golang程序来生成不同地点的开始日期和结束日期ifmonth!=""&&year!=""{varmonthInt,_=strconv.Atoi(month)varyearInt,_=strconv.Atoi(year)timeZone,err:=time.LoadLocation("A

unit-testing - 优步 Cadence : How do I assert the call to workflow. sleep ()?

在我的单元测试中,我想断言调用了workflow.Sleep()。我该怎么做? 最佳答案 可以使用TestWorkflowEnvironment.Now()函数访问模拟时间。例如:before:=testenv.Now()testenv.ExecuteWorkflow(...)after:=testenv.Now()然后断言before和after之间的变化。 关于unit-testing-优步Cadence:HowdoIassertthecalltoworkflow.sleep()?,

go - 有什么方法可以使用 golang std 库来格式化日志(如下所述)?

2018年2月1日下午3:04:05(UTC)|这是日志消息2018-02-01T15:04:05Z|这是日志消息我在gosrc中找到了下一个格式:https://github.com/golang/go/blob/master/src/log/log.go#L37但似乎我无法仅使用那些来做到这一点.. 最佳答案 这里有两个选项:使用log.SetOutput设置自定义编写器。或者使用fmt包而不是只打印到stdout或其他地方-stdlib日志包做的不多而且很容易创建你自己的日志包,它以自定义时间格式输出到stdout(或日志文件

go - 以下代码片段中的 ~once~ 变量是什么意思?

问题是关于从pipe.goofthestandardgolibrary中提取的以下片段中的once变量的用法foronce:=true;once||len(b)>0;once=false{select{casep.wrCh我的理解是,只要len(b)>0循环就不会终止,并且循环至少会执行一次。那为什么不直接写forlen(b)>0{...} 最佳答案 看起来once被用来制作一个do...while(condition);循环,这是Go没有的。 关于go-以下代码片段中的~once~变量

arrays - Go 中的不安全指针 : function call end kills array

我正在编写一个库,我想向调用方返回一个非特定类型的数组(或写入一个数组)。类型可能会有所不同,具体取决于调用者-但是,我可以从我的函数中创建尽可能多的所述类型的对象。一种方法是调用者创建一个数组,然后被调用者填充它——但是,没有办法告诉这个数组将有多长。(有没有办法让被调用者使调用者的数组更大?记住,被调用者只能看到xinterface{}...)我选择的另一种方式是因为我看不到上面的可能性,调用者给我他特定类型的指针,我将它重定向到我创建的对象数组。下面是我的解决方案。我的问题:为什么函数调用后数组为空?他们在我操作后指向同一个数组,他们应该是一样的。我忽略了什么吗?我考虑过GC,但

go - 为什么调用用户定义类型的用户定义 String() 会抛出 "not enough arguments in call to BitFlag.String"?

我列出了《ProgramminginGo》一书中的代码。我对其进行了测试,但效果不佳。error:"notenoughargumentsincalltoBitFlag.String"Goplayground代码:http://play.golang.org/p/FG23LdS_xKtypeBitFlagintfuncmain(){flag:=Active|SendBitFlag.String();}func(flagBitFlag)String()string{...}为什么我会看到这条错误消息? 最佳答案 您需要在BitFlag的