草庐IT

结构化并发

全部标签

go - 为从其他包声明的结构分配一个值

这是我的代码。我将我的结构OperatInfo提取到struct.go并想在worker.go的主包中使用这个结构。结构.gopackagebatchtypeOperatInfostruct{eventIdstringhallIdstringuserIdstringoperatingstringoperatingIDstringipstring}worker.gopackagemainimport("time""fmt""strconv""./kernel/api""./kernel/db""./batch/basic""./batch/struct")varoperatInfobat

go - 使用 initilzer 函数创建的结构不会导出到测试包中吗?

假设我们有一个struct和一个类似这样的结构的构造函数packagemyPackagetypeClientstruct{aTypeAbTypeB}funcNewClient(aTypeA,bTypeB)ConcreteClient{return&Client{a:a,b:b,}}typeConcreteClientinterface{ExportedFunc()}func(c*Client)privateFunc(){//...}func(c*Client)ExportedFunc(){//...}我们在这样的测试包中使用这个客户端var(c=&Client{a:a,b:b,})fu

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

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

performance - Golang goroutine 在添加并发时变慢

我正在研究golang和goroutine的使用。使用此示例代码,在我具有4个逻辑CPU的PC上,我无法理解为什么我没有任何性能提升。如果我添加并发,那么它所花费的时间往往会比没有并发的原始时间慢。2017/10/2713:57:17Starting1threads2017/10/2713:57:27Idroutine:0rate:232.5581402017/10/2713:57:27Currenttotalratewas232.56K/s2017/10/2713:57:27Starting1threads2017/10/2713:57:37Idroutine:0rate:357.1

function - 结构中缺少函数体和字符串标记

这个问题在这里已经有了答案:Functionsignaturewithnofunctionbody(1个回答)关闭4年前。我在Go中发现了一些没有函数体的函数。我知道这意味着Go中的外部函数。但是我在哪里可以找到函数boby呢?typeCreatorfunc(*Beat,*common.Config)(Beater,error)我还在Gostruct中找到了一个字符串。什么意思?typeBeatConfigstruct{//output/publishingrelatedconfigurationsOutputcommon.ConfigNamespace`config:"output"

在另一个文件中转到公共(public)结构

我是GO的新手,不了解一些基础知识-所以我真的不知道如何向谷歌询问。所以我有一个包含2个文件的项目,它们都在main包中——src的根目录。一个文件是main.gopackagemainvar(node*NodeDTO)funcmain(){node=&NodeDTO{ID:1}}还有一个是dto.gowithpackagemaintypeNodeDTOstruct{IDint}所以main.go告诉我-“undefined:NodeDTO”。但是如果我在main.go附近创建一个dirdto并从那里使用我的NodeDTO就像packagemainimport"another_tcp_

go - 如何在 Go/Golang 中使用 map[string]string 或自定义结构?

关闭。这个问题需要detailsorclarity.它目前不接受答案。想要改进这个问题吗?添加详细信息并通过editingthispost澄清问题.关闭4年前。Improvethisquestion在阅读一些开源代码时,我发现了以下代码:typeValuesmap[string]string还有:typeValuestruct{keystringvaluestring}typeValues[]Value那么,这两个有区别吗?谢谢! 最佳答案 map是无序的,slice保持插入顺序。 关于

go - 在golang中动态创建结构数组

我尝试创建一个接受任何结构值的通用函数并创建该结构类型的数组。这是我试过的代码。但我收到错误“t不是一种类型”。我该如何实现。typeRegAppDBstruct{nmstringdata[]interface{}}funcCreateRegTable(tblstring,recinterface{})RegAppDB{t:=reflect.TypeOf(rec)fmt.Println(t)returnRegAppDB{"log",[]t}} 最佳答案 Go不支持泛型,任何类似的尝试都不会成功。在您的具体情况下,存在几个关键问题:您

go - 展平结构并将其转换为 map[string]string

关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。关闭4年前。Improvethisquestion我有各种不同的嵌套struct,例如:typeMyInnerTypestruct{helloint}typeMyTypestruct{foostringbarMyInnerType}使用这样的声明,例如:x=&MyType{foo:"hi"bar:MyInnerType{hello:1}}我想像这样将它转换成map[string]string的扁平化map:{"foo

go - 在go中合并两个结构(相同类型)?

我有点被困在这里。我想编写一个(通用的,如果可能的话!)函数,它将合并两个相同类型的结构——它可能不仅包含基元,还包含结构,甚至slice。由于业务层面对我们的限制,我们不能真正使用mergo,所以我需要写这个。但是我有点难以获得任何值得讨论的结果-我不是在寻找一个完全有效的解决方案(如果你有代码,它肯定会有所帮助)但我真的需要一些关于这个算法可能是什么样子的指导。我想我想做一些事情:funcMerge(sourceCustomStruct,targetCustomStruct)resultCustomStruct{//Maybesomekindofsonworktogetmytwos