草庐IT

go-mocket

全部标签

go - Go 中 Print 和 print 的区别

这个问题在这里已经有了答案:Differencebetweenfmt.Println()andprintln()inGo(5个答案)关闭3年前。Go语言中的fmt.Print("printsomething")和justprint("printsomething")之间有什么区别。varaintfmt.Print("InPrint",&a,"\n")print("Inprint",&a,"\n")两者提供相同的结果。结果:InPrint0xcSameAddressLocationInprint0xcSameAddressLocation但是当我这样做时:ar:=[]int{1,2,3,

go - 错误;不能将 imageName(类型 ImageName)用作 appendgo 中的 dao.ImageName 类型

我正在用Go重构服务器端逻辑,但出现无法解决的错误。・client:react/axios・api:golang/gin・web-server:nginx・db:mysql・container:docker・ci-tool:travis・deploy:awselasticbeanstalk服务.gofuncGetSingleArticleService(c*gin.Context,db*sql.DB)Article{article,rows:=dao.GetSingleArticleDao(c,db)forrows.Next(){imageName:=ImageName{}err:=r

go - 避免在带有接口(interface)的范围内的 goroutine 中进行数据竞争

我有以下for...rangeblock,它使用goroutine调用url。funccallUrls(urls[]string,reqBodyinterface{})[]*Response{ch:=make(chan*Response,len(urls))for_,url:=rangeurls{somePostData:=reqBody//thisjustseemstocopyreference,notadeepcopygofunc(urlstring,somePostDatainterface{}){//serviceMutex.Lock()//deferserviceMutex.

Go 错误处理技术

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭3年前。Improvethisquestion我刚刚开始使用Go。我的代码开始有很多这样的东西:iferr!=nil{//handleerr}或者这个iferr:=rows.Scan(&some_column);err!=nil{//handleerr}在Go中是否有一些好的习惯用法/策略/最佳实践来检查和处理错误?编辑以澄清:我并不是在发牢骚或建议Go团队想出更好的东西。我在问我是否做对了,或者我是否错过了社区提出的一些技术。谢谢大

go - Go 中的延迟似乎会增加延迟

我在Go中使用互斥体进行同步。下面是代码func(c*MyStruct)Put(keystring,valueinterface{}){c.mu.Lock()deferc.mu.Unlock()val,found:=c.items[key]iffound{item:=val.Value.(*Item)item.Value=valueitem.Expiration=time.Now().Add(c.ttl).UnixNano()return}ele:=c.list.PushFront(&Item{key,value,expirationTime})c.items[key]=ele}当我对

go - 如何解析 "2019-09-19 04:03:01.770080087 +0000 UTC"时间戳

这个问题在这里已经有了答案:ParsingRFC-3339/ISO-8601date-timestringinGo(8个答案)关闭3年前。我将如何解析这个时间戳?“2019-09-1904:03:01.770080087+0000UTC”我尝试了以下方法:formatExample:=obj.CreatedOn//obj.CreatedOn="2019-09-1904:03:01.770080087+0000UTC"time,err:=time.Parse(formatExample,obj.CreatedOn)check(err)fmt.Println(time)但我得到的输出是:0

go - 为什么 Golang 需要接口(interface)?

在Golang中,我们使用带有接收方法的结构。到目前为止一切都很完美。但是,我不确定什么是接口(interface)。我们在结构体中定义方法,如果我们想在一个结构体上实现一个方法,我们无论如何都会在另一个结构体下再次编写它。这意味着接口(interface)似乎只是方法定义,只是在我们的页面上占用额外不需要的空间。有没有例子可以解释为什么我需要一个接口(interface)? 最佳答案 接口(interface)是一个太大的话题,无法在这里给出全面深入的答案,但有些东西可以使它们的用途变得清晰。接口(interface)是一个工具。

go - 如何从 exec.StdoutPipe() 获得输出的颜色?

我希望能够无缝打印通过io.ReadCloser传递的未知(用户定义)命令的输出。bufio.NewScanner读取标准并正确打印文本,但是子进程打印的颜色未被记录并通过管道传递(或者我不知道如何访问它)。我尝试使用execErr:=syscall.Exec(binary,cmd.Args,os.Environ())但是因为这接管了go进程,所以我无法获得进程数组运行。//SpawnGroupspawnsagroupofprocessesfuncSpawnGroup(cmds[]*exec.Cmd){spawnWg:=&sync.WaitGroup{}spawnWg.Add(len(

Go:调用函数时如何使用命名参数?

如何在使用命名参数时调用函数?(如果不清楚什么是命名参数,这里有一个usingtheminPython的例子)我想做的事的例子:funcAdd(aint,bint)int{returna+b}funcmain(){c:=Add(a:1,b:3)returnc}但是,上面给出了错误:unexpected:,expectingcommaor)(指的是紧跟在'a'之后的':') 最佳答案 Go没有命名参数。我知道在Go中最接近命名参数的是使用结构作为输入。因此,对于您的示例,您可以这样做-typeInputstruct{AintBint}

go - 为什么这段Golang代码不行?

_,error:=connection.Read(buffer)buffer:=make([]byte,BUFFER_SIZE)splited:=strings.Split(string(buffer),"")switchsplited[0]{case"TEST":connection.Write([]byte("TESTCONNECTIONOK"))log.Printf("TESTCOMMAND")break;如果我在客户端写“TEST”,服务器不会输入case语句。但是如果我从客户端发送“TESTSOMETHING”,服务器将按预期输入它。这是go-lang的bug吗?