草庐IT

行为监控

全部标签

go - 同步/原子 StoreInt32 奇怪的行为

此代码已简化并描述了我的问题。atomic.StoreInt32似乎不起作用,但我不确定为什么。packagemainimport("fmt""sync/atomic")typeslavestruct{failedint32}funcNewSlave()slave{returnslave{0}}func(workerslave)Fail(){atomic.StoreInt32(&worker.failed,1)//Here'stheproblem.}func(workerslave)IsFailed()bool{failed:=atomic.LoadInt32(&worker.fail

Golang 导入的字段与标准字段声明的行为不同

我将尝试简化问题,而不是将整个项目纳入范围,因此如果您有任何疑问,我会尝试更新更多信息。我有3个正在使用的结构:typeTicketstruct{IDbson.ObjectID`json:"id"bson:"_id"`InteractionIDs[]bson.ObjectId`json:"interactionIds"bson:"interactionIds"`TicketNumberint`json:"ticketNumber"bson:"ticketNumber"`Activebool`json:"active"bson:"active"`//Otherfieldsnotinclu

oop - 需要帮助理解 Go 中的 `map[String]type` 行为

请看这段代码:packageactivityimport("fmt""strconv""time")typeActivitystruct{yearContributionsmap[string]weekContributions}typedayContributionsstruct{Datetime.TimeContributionint}typeweekContributionsstruct{NotationstringAllDays[]dayContributions}func(currentWeekContribution*weekContributions)addContrib

带有 for 循环的 golang channel 行为

我很好奇channel的行为以及它们与循环相关的工作方式。假设我有以下代码:消费者tick:=time.Tick(time.Duration(2)*time.Second)for{select{case我有一个goroutine具有以下内容:处理器for{select{casecanProcess:=如果消费者推送到channel的速度比处理器完成同步过程的速度快,会发生什么情况?它们是堆积起来等待处理器完成,还是跳过一个“节拍”?如果它们堆积起来,是否存在内存泄漏的可能性?我知道我可以将同步过程放在goroutine中,但这实际上是为了了解channel的行为方式。(即我的示例有一个

go - twoSum 函数对不同的数组输入有不同的行为

当我运行以下代码时,我得到了预期的答案[3,4],这是加起来成为我的目标变量的2个数字的索引。但是,当我将myArray输入更改为[]int{1,2,3,4,6,11,4,12}(我删除了最后6个)时,我感到panic。请帮助我理解为什么会这样。functwoSum(nums[]int,targetint)[]int{length:=len(nums)-1fori:=rangenums[:length]{forj:=rangenums[i+1:]{ifnums[i]+nums[j]==target{return[]int{i,j}break}}}panic("shouldneverha

go - time.Timer 的行为

我是Go的新手,时间包让我有点困惑。所以我正在制作一个聊天框,想法是当你发送消息时,计时器重置为20秒,如果你在20秒内没有回复,你就会被踢出局。我的代码只有在该人输入内容时才有效,但如果他们从未输入任何内容,他们就不会被踢出局。我尝试在for循环之前应用Stop(),但它不起作用。我应该在循环前后而不是在for循环内执行所有计时器吗?func...{timer:=time.NewTimer(20*time.Second)forinput.Scan(){gofunc(){ 最佳答案 你可以使用time.AfterFunc;例如;pa

go - 为什么当一个类型实现一个接口(interface)时,行为会有所不同?

谁能告诉(或链接到哪里阅读),为什么当一个类型实现了一个接口(interface)行为有所不同(取决于如何转移收件人)?在这里它是这样工作的:typeGetNamerinterface{GetName()}typePersonstruct{PersonNamestring}func(pPerson)GetName(){fmt.Println(p.PersonName)}typeData[]GetNamervard=Data{Person{"Vasya"},}但是,如果我通过链接传递收件人:(p*Person)我收到类型(Person和GetNamer)不匹配的错误。

go - Go 结构中的意外行为

这个问题在这里已经有了答案:Golangmethodwithpointerreceiver[duplicate](2个答案)关闭4年前。我在Go结构中遇到了一个奇怪的行为。我可能误解了一些东西,但是当我这样创建时:typeITestinterface{Foo()stringBar(string)}typeBasestruct{valuestring}func(bBase)Foo()string{returnb.value}func(b*Base)Bar(valstring){b.value=val}//NotimplementingITesttypeSubstruct{Base}//N

google-app-engine - 关于获取datastore的Cursor行为的问题

我有一个关于获取Cursor的问题目标函数:https://godoc.org/google.golang.org/appengine/datastore#Iterator.Cursor从下面的代码可以看出,在获取Cursor时设置了偏移量https://github.com/golang/appengine/blob/master/datastore/query.go#L702-L705当我使用GCP控制台的堆栈跟踪执行此函数时检查结果时,Insights显示警告Issue:Useofoffsetindatastorequeries.Description:Yourappmade1r

string - 附加到二维字符串 slice 时的奇怪行为

Thisquestionalreadyhasanswershere:Golangslicereferenceconfusion(3个答案)去年关闭。我正在尝试在Go中实现堆的置换算法。它应该返回给定输入集的所有可能的排列。funcPermute(in[]string)[][]string{c:=make([]int,len(in))out:=make([][]string,0)fori:=rangeout{out[i]=make([]string,0)}fmt.Println(in)out=append(out,in)i:=0foriPrintln语句显示预期的输出。返回的out值具有