草庐IT

c++ - Bruce Eckel 的 Thinking in C++ 中指向成员的指针

全部标签

go - 指向表达式结果的指针

我可以在不在Go中创建新变量的情况下创建一个指向表达式结果的指针吗?packagetestfuncfoo(*uint32){}funcmain(){foo(&(uint32(time.Now().Unix())))//thislinegivesmeerror//cannottaketheaddressofuint32(...} 最佳答案 在问题评论中,OP说protobuf消息需要指针。proto包提供了用于创建指向整数和其他值的指针的辅助函数。使用proto.Uint32获取指向uint32的指针的函数。x.Time=proto.

pointers - 调用结构属性方法时 Golang 结构指针引用丢失

我正在尝试使用struct来管理树上的访问节点。每当我访问父节点的子节点的方法时,后续调用的父引用就会丢失(即parent.child.method(child)->[parentbecomesnil]->parent(thepreviouschild).child...等等).这是我文件中的错误片段。typeNodestruct{Left*NodeRight*Nodevalueint}func(parent*Node)determineSide(child*Node)(Node,Node){ifchild.Valueparent.Value{ifparent.hasRightNode

go - 如何知道结构或结构指针是否实现接口(interface)

我需要知道结构或指向该结构的指针是否实现了给定的接口(interface)。//Youcaneditthiscode!//Clickhereandstarttyping.packagemainimport"fmt"funcmain(){varaA=A{i:5,}Serialize(a)Serialize(&a)}typeSerializableinterface{//Serialize()string//Deserialize(string)Serializebyte()[]byteDeserializebyte(b[]byte)(bytesReadint)}typeAstruct{i

go - 我对包字节中的 Go 指针用法有疑问

我有一个关于Go中指针用法的问题。链接在这里:https://golang.org/pkg/bytes/#example_Buffer.在typeBuffer部分,第一个例子:typeBufferstruct{//containsfilteredorunexportedfields}funcmain(){varbbytes.Buffer//ABufferneedsnoinitialization.b.Write([]byte("Hello"))fmt.Fprintf(&b,"world!")b.WriteTo(os.Stdout)}然后在func(b*Buffer)Write(p[]b

pointers - 尽管映射始终是引用类型,但如果它们是从非指针接收器返回的呢?

据说映射是Go中的引用类型,因此当从函数返回它们时,您不需要将其作为指向映射的指针传递,以使更改在函数体外部可见。但是,如果所述映射是从非指针结构上的方法返回的呢?例如:typeExampleMapHolderstruct{theUnexportedMapmap[string]int}func(empExampleMapHolder)TheMap()map[string]int{returnemp.theUnexportedMap}如果我调用TheMap(),然后修改其中的值,即使接收者不是指针,此更改是否在其他地方可见?我想它会返回对属于ExampleMapHolder副本的map的

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

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

go - 在 "A Go Tour"中,如何修改接口(interface)以在指针上要求方法?

在"AGoTour"onInterfaces我们有这个界面:typeAbserinterface{Abs()float64}说明Vertex这个类型不满足上面的Abser:typeVertexstruct{X,Yfloat64}func(v*Vertex)Abs()float64{returnmath.Sqrt(v.X*v.X+v.Y*v.Y)}如何修改Abser接口(interface),使Vertex满足它?(如果它不再满足完整示例中的MyFloat也没关系。)在我发布这个问题之前,我花了几个小时搜索和挠头,但在发布之后我发现了另一个SO问题,它涵盖了类似的Material,可能对

go - 为什么 golang 有结构类型的值和指针

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭6年前。ImprovethisquestionGo的设计目标之一就是简单。但是Go有结构类型的值和指针,我认为这让开发人员难以选择,而java和javascript有一个非常简单的规则:基本类型总是值,对象类型总是指针。为什么Go不采用来自java和javascript的这个简单规则?或者与指针相比,值有什么重要的优势吗?

go - 如何在函数中传递指向结构的指针?

我想知道如何将*Type替换为?什么地址里面有结构?//mycode.gopackagemainimport"fmt"funcout(k*Type){fmt.Println(k)}funcmain(){typeDataIPstruct{Title,Descstring}Data:=DataIP{"Hello!","HelloGO!",}out(&Data)} 最佳答案 您需要在main()之外定义类型DataIP,该类型在包的范围内,而不仅仅是在main函数内:packagemainimport"fmt"typeDataIPstru

go - 作为参数传递时结构成员的范围可见性?

例如,通过传递结构调用json.Decoder.Decode时type_Samplestruct{firststring//thiswillnotbefilledbecauseitstartswithlowercaseletterSecondstring//itisOK.}...varsample_Sampleerr:=decoder.Decode(&sample)根据LanguageSpecification写的:Exportedidentifiers¶Anidentifiermaybeexportedtopermitaccesstoitfromanotherpackage.Anid