草庐IT

go-import

全部标签

go - 为什么我得到一个引用接口(interface)的空变量?

packagemainimport("fmt""net/http""sync""time")typemyInterfaceinterface{doFunc()bool}typemyStructstruct{myValuestringsimyInterface}funcnewStrcut(simyInterface)*myStruct{return&myStruct{si:si}}varmyS*myStructfuncmain(){myS=newStrcut(&newStrcut{})myS.myValue="test"ifmyS.doMyLogic(){return}}func(s*m

go - 如何修复 Golang 中单值上下文错误的多值?

packagemainimport"fmt"funcmain(){fmt.Println("Enteranumber:")varaddendOneint=fmt.Scan()fmt.Println("Enteranothernumber:")varaddendTwoint=fmt.Scan()sum:=addendOne+addendTwofmt.Println(addendOne,"+",addendTwo,"=",sum)}这引发了一个错误:multiplevaluesinsingle-valuecontext.为什么会发生这种情况以及我们如何解决它?

go - 在 Golang 中连续运行 io.Copy(os.Stdout, &r) 结果不同

我在玩Golang。关于io.Copy我在代码中放置了2个连续的io.Copy,但我希望它输出两次结果(testtesttest)。但是第二个是零。谁能帮忙解释一下为什么?谢谢packagemainimport("io""os""strings""fmt")typetestReaderstruct{wio.Readerstrstring}func(tt*testReader)Read(b[]byte)(nint,errerror){io.Copy(os.Stdout,tt.w)n,err=tt.w.Read(b)iftt.w!=nil{return0,io.EOF}return}fun

go - Golang 中的返回接口(interface)

假设我们想在error接口(interface)上扩展Error()函数。我们可以简单地创建一个从实现Error()方法的字符串派生的结构。例如:typeNewUserstruct{EmailstringPasswordstring}typeErrMissingFieldstringfunc(eErrMissingField)Error()string{returnstring(e)+"isrequired"}func(u*NewUser)OK()error{iflen(u.Email)==0{returnErrMissingField("email")}iflen(u.Passwor

go - serveHTTP 实用程序从哪里来的所谓的裸函数

我有这个工具:typeHandlerstruct{}func(hHandler)Mount(router*mux.Router,vPeopleInjection){router.HandleFunc("/api/v1/people",h.makeGetMany(v)).Methods("GET")}上面调用这个:func(hHandler)makeGetMany(vPeopleInjection)http.HandlerFunc{typeRespBodystruct{}typeReqBodystruct{Handlestring}returntc.ExtractType(tc.Type

go - 函数在返回语句时不退出

我有一个奇怪的问题。我在玩围棋时发现了一些我无法理解的非常奇怪的行为。当我运行findMatchingSum函数时,它搜索预期的总和,如果总和更大,我将最后一个索引减1,如果更大,则将第一个索引递增一个。然而,当我调试代码时,它首先命中if语句并且应该返回true,但是它直接运行并运行最后一个elseif语句。困惑从这里开始。在第3次迭代中,它遇到了进入该block的if语句,但没有退出该函数。这是代码;packagemainimport"fmt"vararr=[]int{1,2,4,4}funcmain(){s:=findMatchingSum(arr,8,len(arr)-1,0)

go - 使用该结构的内部函数检查映射中是否存在值

我有这个结构typeZonesmap[uint64]Zone我想有一种方法可以在该映射中找到一个值,就像这样。func(z*Zones)findById(iduint64)(Zone,error){ifzone,ok:=z[id];ok{returnzone,nil}else{returnzone{},errors.New(fmt.Sprintf("Zone%dnotfound",id))}}但是在这一行中:ifzone,ok:=z[id];ok{我收到这个错误:Assignmentcountmismatch:2=1.有很多链接表明我们可以使用该行检查map中是否存在某个值,我不知道发

go - 使用反射确定类型是否为字符串

这里有一些关于如何在运行时确定对象类型的现有答案..godhelpusifreflect.TypeOf(err)==string{}不编译ifreflect.TypeOf(err)=="string"{}既不是那个也不是这个:ifreflect.TypeOf(err).Kind()=="string"{}我们如何做到这一点?如果我使用其中一个答案给出的typeof函数,我会得到: 最佳答案 比较字符串ifreflect.TypeOf(err).String()=="string"{fmt.Println("hello")}或使用ty

go - 将 slice 作为参数列表传播

我有这个功能:funcMiddleware(adapters...interface{})http.HandlerFunc{//...}我正在尝试通过以下方式调用它:middleware:=[]mw.Adapter{mw.Error(),mw.Auth("x-huru-api-token")}router.HandleFunc("/person_data_field",mw.Middleware(middleware...,h.makeGetMany(v))).Methods("GET")虽然这没有编译,但我得到:在任何情况下,我都需要展开slice,以便它作为多个参数发送,而不仅仅是

loops - 是什么导致空的 Go for 循环锁定程序?

当我学习Go时,我最初使用一个空的for循环编写我的短程序,以阻止程序在我使用go关键字运行我的测试函数时退出。然而,随着我的测试/学习程序规模的增长,整个程序有时会在随机位置卡住并且调试器会断开连接,从而使调试变得非常困难。我最终从IRC上的一些讨论中了解到原因是空循环,并将其替换为阻塞channel,但除了与Go处理调度的方式有关外,我从未了解原因。如果有一个空的无限循环,后台的什么机制会导致独立的go-routines锁定整个程序,即使有大量的内核分配给程序? 最佳答案 空的for循环不会阻塞。它使CPU忙于一遍又一遍地执行相