草庐IT

Go + Protocol buffers 表现得很奇怪

我正在为我正在进行的项目编写一个基于服务的服务器,它是用Go编写的,并使用ProtocolBuffers进行服务间通信。一切正常,直到我添加了名为DeviceRequest和DeviceResponse的协议(protocol),现在编译器找不到它们,而协议(protocol)的go源存在并设置在我的GOPATH。WebStorm也能找到它们,但出于某种原因编译器没有找到。奇怪的是,Go源不再存在的旧协议(protocol)仍然有效(Webstorm也无法识别它们),请参见这些屏幕截图我已经尝试删除我的GOPATH中的文件,但是没有用。我的猜测是go使用了某种缓存内存,但我在网上找不到

go - 使用接口(interface)参数的奇怪行为

当我使用*[]interface{}调用带有interface{}参数的函数时,行为是预期的,但是当我使用[]interface{},然后将参数与&一起使用为什么不起作用?funcrouteWarehouses(engine*gin.Engine){vartest[]database.Warehousesrouter.GET("/",genericReads(test))}funcgenericReads(iinterface{})func(c*gin.Context){returnfunc(c*gin.Context){//WhenicallgenericReadswith`test

go - 奇怪的行为 GoLang 将字符串存储到变量中的长度限制为 64 字节

我一直在尝试将一个大字符串存储到GoLang中的字符串变量中,但由于某些未知原因,GoLang将字符串的长度限制为64字节这个字符串连接的主要目的是在运行时根据用户输入生成couchbase的N1QL查询userInput:=[]string{"apple","boy","cat","dog"}varbufferstringbuffer="SELECT*FROMDBWHEREDB.ITEM_NAME="+userInput[0]+"ORDB.ITEM_NAME="+userInput[1]在这种情况下,如果我在变量缓冲区上进行调试,例如,我可以看到它只包含直到“SELECT*FROMD

去河豚奇怪的东西

我有以下函数,它使用Blowfish对字符串进行编码。如果我只将字符串放入字节数组,它就可以工作。问题出在线路上cipher.Encrypt(加密[0:],src)funcBlowFish(strstring){key:=[]byte("supersecretkey")cipher,err:=blowfish.NewCipher(key)iferr!=nil{log.Fatal(err)}//veryweirdthatIgetindexoutofrangeifIinsertavarsrc:=[]byte(str+"\n\n\n")varenc[512]bytecipher.Encryp

go - golang 中嵌套 slice 中删除元素的奇怪行为

我正在做一个golang项目。我正在尝试维护现有slice中的slice,其中我的新slice不包含现有slice元素。我试过这样的代码:packagemainimport("fmt""reflect")funcmain(){savedArr:=make(map[string][]int)newArr:=make(map[string][]int)days:=[]string{"saturday","friday","sunday"}newSpotsArr:=[]int{10,20,30,40,50,60,70,80,90,100,101}savedArr["saturday"]=[]

go - 奇怪的零/非零行为

我的项目中有以下代码:mod:=srt.PrimaryModule()ifmod!=nil{mods[mod.Name()]=mod}当它执行时,我得到:PANIC:runtimeerror:invalidmemoryaddressornilpointerdereference堆栈就在第三行。(是的,它是mod取消引用,mapmods是在上面一行创建的...)那么,什么时候nil值不等于nil?为什么?srt.PrimaryModule()返回一个接口(interface)类型,Module,带有定义的Name()方法返回string。在这种特殊情况下,srt的类型为StdReflec

function - 传递值时与通过引用传递时 map 的奇怪突变(Golang)

在第一种情况中,我按值将map传递给:包主import("fmt""time")functimeMap(zmap[string]interface{}){z["updated_at"]=time.Now()}funcmain(){foo:=map[string]interface{}{"Matt":42,}timeMap(foo)fmt.Println(foo)}输出是一个静音贴图:map[updated_at:2009-11-1023:00:00+0000UTCMatt:42]在第二种情况中,代码几乎相同,但通过引用传递:packagemainimport("fmt""time")f

go - 我有一个奇怪的错误

给出了以下两个函数。funcmain(){index:=int(0)for{Loop(index)index=(index+1)%86400//Maxinterval:1daytime.Sleep(1*time.Second)}}funcLoop(indexint){ifindex%10==0{godoSomething...}}我想每10/60/3600秒执行一次。所以我认为带模数的递增索引应该做到这一点。但我注意到(尤其是在高流量服务器上)它似乎跳过了一些循环。我查看了我的日志,有时每10秒就会有一些东西,但有时会有长达1分钟的间隔。有人知道为什么会这样吗?

go - 执行命令时出现问题,其中包含奇怪的字符

我正在尝试调用内置函数find来打印子文件夹my-files中所有文本文件的内容。我知道有更简单的方法可以做到这一点,但我需要让它与exec一起工作。我怀疑exec没有正确处理引号。我的初始代码如下:fullCmd:="findmy-files-maxdepth1-typef"cmdParts:=strings.Split(fullCmd,"")output,_:=exec.Command(cmdParts[0],cmdParts[1:]...).CombinedOutput()fmt.Println("Outputis...")fmt.Println(string(output))这

linux - Go Get OAuth2 在 Linux Mint 上给我奇怪的错误

尝试跟随https://jacobmartins.com/2016/02/29/getting-started-with-oauth2-in-go/当我运行gogetgolang.org/x/oauth2时,没有任何异常出现,但是当我尝试使用gorunmain.go运行代码时我在终端中得到以下信息:#google.golang.org/grpc/credentials../../../google.golang.org/grpc/credentials/credentials_util_pre_go17.go:58:32:error:referencetoundefinedfieldo