草庐IT

同一性

全部标签

Go函数写入同一个 map

我正在尝试熟悉goroutines。我编写了以下简单程序来将1-10的数字平方存储在map中。funcmain(){squares:=make(map[int]int)varwgsync.WaitGroupfori:=1;i最后,它会打印一张空map。但是在go中,map是通过引用传递的。为什么打印一张空map? 最佳答案 正如评论中指出的,您需要同步对map的访问,您对sync.WaitGroup的使用不正确。试试这个:funcmain(){squares:=make(map[int]int)varlocksync.Mutexva

go - Cookie 不会在同一域的不同页面之间持续存在

在我的部分代码中,我保存了一个这样的cookieifencoded,err:=s.Encode(USER_ID_COOKIE_NAME,value);err==nil{user_id:=&http.Cookie{Name:USER_ID_COOKIE_NAME,Value:encoded,Path:"/",HttpOnly:true,}http.SetCookie(w,user_id)}0当我这样做时,它会保存一个cookie,但是当我尝试转到另一条路径时,cookie不存在。例如:登录后,即时消息位于路径“/oauth/square”,然后当我单击指向“/settings”的链接时,

go - 导出的方法在同一个包中不可用

我有一个小的golang项目,在main.go文件中有一些处理程序引用session.go文件中的session相关方法。两者在文件顶部都有packagemain。session.go文件中的函数都以大写字母开头(即它们是公共(public)/导出方法)。然而,当我运行main.go文件时,它说位于session.go中并从main.go调用的方法是未定义。为什么会这样,如何解决。我正在运行项目gorunmain.go主.gofunclogout(whttp.ResponseWriter,r*http.Request){ClearSession(w,r)....}session.gof

http - TCP 是同一主机中 Go 程序之间通信的最佳方法吗?

假设我有两个独立的Go程序在我的本地主机上运行,​​就性能而言,TCP是否是在两个程序之间传输数据的最佳方法? 最佳答案 简短的回答是否定的。TCP/IP堆栈很慢,尤其是TCP部分。因此,就性能而言,您最好使用本地进程间通信方法,例如应用程序或Unix套接字之间的共享内存。如果您必须使用网络堆栈进行通信(例如,您计划在主机之间移动应用程序),那么UDP或原始套接字是性能方面的最佳选择。只有当你:必须使用网络并且您需要一个可靠的通信channel,那么TCP是一个不错的选择。因此,只需浏览您的要求并确定它是否是最适合您的方法。

go - 在同一个共享 channel 上并发选择

我在想如果多个goroutines在一组channel上执行select会发生什么,其中一个/一些在它们之间共享并且当它们都在等待时,共享channel变为可用.运行时会处理这种情况并只允许一个goroutine访问channel并进行读/写吗? 最佳答案 上面的评论都回答了。您也可以编写一些代码并亲自查看。这些线上的东西https://play.golang.org/p/4ZQLwO9wvw 关于go-在同一个共享channel上并发选择,我们在StackOverflow上找到一个类似

pointers - 在 Golang 中取消引用指向同一类型的指针变量而无需引用

我的应用程序有一个事件类型:typeEventstruct{Idstring}有时我有这种类型的实例和引用,有时没有:varevent*Event但是函数需要这种没有指针的类型:funcProcessEvent(eventEvent)所以我不能在这个函数中使用我的指针变量。也许有将*Event转换为Event的解决方案?或者我需要重构我的代码,让所有代码都没有指针?我使用这个解决方案,但我不喜欢它,因为我需要复制我的代码:event2:=Event{Id:event.Id} 最佳答案 要从指针转换,您需要取消引用指针:*event来

Golang 多个 goroutine 通过引用共享同一个变量

我正在尝试运行多个goroutine来修改通过引用传递的相同变量。但我确信我实现它的方式在功能上是不正确的。尽管它似乎在我的测试中有效,但我感觉如果第二个goroutine比第一个goroutine花费更长的时间运行,那么当第一个goroutine完成时,这种模式会结束父函数。我希望得到您的意见/建议/忠告。packageauthimport("regexp"zxcvbn"github.com/nbutton23/zxcvbn-go""golang.org/x/net/context")typeAuthServicestruct{}funcNewAuthService()*AuthSe

mysql - 多个 rows.Next() 在同一时间 golang sql/database

我正在开发一个获取用户的功能。我的问题是我必须将两个查询的结果作为rows.Next()和rows1.Next()中的一个结果返回,例如user_id,subject,phone.这是我拥有的,但它不起作用。你能帮我提出一些建议吗:funcGetUsers()(users[]Users,errerror){users=make([]Users,0)rows,err:=db1.Query("SELECTuser_id,subject,phoneFROMuserslimit11")rows1,err:=db1.Query("Selectbodyfromuserslimit11")defer

go - 为什么 goroutines 不处理同一个文件两次?

我正在查看有关goroutines和channel等模式的goroutines博客文章。在bounded.go例如我看到这个:paths,errc:=walkFiles(done,root)//Startafixednumberofgoroutinestoreadanddigestfiles.c:=make(chanresult)//HLcvarwgsync.WaitGroupconstnumDigesters=20wg.Add(numDigesters)fori:=0;i既然每个摘要器都在处理相同的paths集合,为什么它不重复同一个文件两次? 最佳答案

go - 同一网络中的应用程序和服务器之间的通信

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭3年前。Improvethisquestion我正在开发将在kubernetes上运行的CI/CD工具。该应用程序将负责创建一个k8s作业对象,该对象将被视为一个slave以运行管道。图像,slave将运行完全取决于用户,所以我无法控制它,除了它会在与CI/CD应用程序相同的本地网络中运行。我的问题是;在这种情况下,如何使CI/CD工具与从属之间进行通信?为了为此添加更多上下文,我想创建类似于Jenkins的东西。Jenkins与kubernetes