草庐IT

智能指针

全部标签

pointers - go - 修改指向 slice 的指针不会修改原始指针

我尝试创建一个结构,其中一个字段是指向现有空slice的指针。然后我修改结构体的字段,稍后我尝试从原始slice中获取新内容-但它仍然是空的!这是演示代码:packagemainimport("fmt")typeAstruct{B[]int}funcmain(){c:=[]int{}a:=&A{B:c,}a.B=append(a.B,5)fmt.Println(c)fmt.Println(a)}这里的结果是:[]&{[5]}问题是——如何从原始slice和结构的字段中获取实际的slice内容?我在这里没有将slice作为参数传递给函数。 最佳答案

go - 为 big.Int 创建了类型别名 - 但我无法使用其指针接收器设置它?

我认为类型别名比嵌入结构更优雅。你看,如果我创建一个嵌入big.Int的新类型BigInt,我必须注意嵌入的big.Int始终被初始化,并且除非我重新实现big.Int,比如Cmp、Add、Sub,所有依赖于这个新类型的代码都需要知道BigInt的方法实际上接收到一个big.Int对于他们的论点。这是愚蠢的。所以我尝试给类型起别名。typeBigIntbig.Int//StringcastsBigIntintobig.IntandusesitsStringmethod.func(b*BigInt)String()string{bc:=big.Int(*b)returnbc.String

arrays - 即使初始化也没有指针取消引用

我的目标是声明一个空的二维数组,然后在每次do()运行时对其进行初始化并填充值。问题是即使我正在初始化数组,我也会得到一个nil指针取消引用。这是我试图在服务器模拟器上完成的一个简单版本。packagemainimport"fmt"typeSrvstruct{A*[][]int}func(sSrv)init(){arr:=make([][]int,0)*s.A=arr}funcmain(){s:=Srv{nil}s.init()printSlice(*s.A)do(s.A)do(s.A)}funcprintSlice(s[][]int){fmt.Printf("len=%dcap=%d

json.Unmarshal 接口(interface)指针与稍后的类型断言

因为我经常解码http.Response.Body,我想我可以写一个函数来处理读取、关闭和解码成各种不同结构的所有麻烦。这就是为什么我引入了一个函数funcunmarhalInterface(closer*io.ReadCloser,v*interface{})error然后可以用t:=i.(T)断言返回值.根据thisanswer我已经把它包装成*interface{}类型的值了,但因为覆盖类型是interface{}而不是myStruct,json包实现选择map[string]interface{}.之后类型断言失败(当然)。有什么我遗漏的或需要这个实现“手动”的类型断言,这意味

go - 如何将指针值转换为原始值

这个问题已经有了答案:HowdoIdereferenceapointerinGo?1答我有一个类型为ip的net.ip变量*net.IP,我将它传递给一个只接受net.IP的查找函数,得到错误;cannotuseip(type*net.IP)astypenet.IPinargumenttoLookup 最佳答案 这就是我在评论中添加的代码。罗比的暗示packagemainimport("fmt")funcderefPointer(importantType*int){fmt.Println(*importantType)}funcm

Go 方法指针接收者的语法

在go中,也可以为指针接收器定义一个方法。Go可以解释代码语法如下:在方法的定义中,只写接收者的指针类型就足够了,在函数定义中你不需要解引用指针来访问你想访问的内存中的对象。在函数调用中,你不需要在指针类型上调用函数,我的意思是在引用上。Go可以理解你的意思。typeBoxstruct{colorstring}varbBox基于此,golang代码片段在下面等效的原因是什么?除了方便或代码速记之外,还有其他原因吗?走吧,但经典的C方式也行得通:func(b*Box)setColor(cstring){b.color=c}b.setColor("blue")经典的C方式:func(b*B

go - 指针引用未存储在我的 go 程序中的结构中

我是go-lang的新手,我试图弄清楚如何正确地使用结构和依赖注入(inject)。我有点卡住了,因为我无法正确存储对另一个结构的引用。这是我生成CommandController的方法。存在对iris.Application的有效引用。funcProvideCommandController(application*iris.Application,commandRepositorycommand.CommandRepository)(*interfaces.CommandController,error){commandController:=interfaces.CommandC

pointers - 您可以将多个值中的部分或全部作为函数的指针返回吗?

在使用Go时,我遇到了各种错误,试图在返回另一个值的同时返回一个字符串作为指针。像这样的东西(请原谅这不是运行代码,我只是写它来了解我想做什么,因为我不知道如何让它工作):funcA(sstring)*string,int{//Stuffreturn&a,b}*c,d:=A("Hithere.")当我尝试各种组合say时,将字符串(var.a)作为指针返回时,我遇到了各种错误。这很简单,有许多返回单个变量的示例,但我不确定是否可以使用多个返回值。抱歉,如果这看起来是一个非常基本的问题,我仍然在思考Go。 最佳答案 如前所述here在

pointers - 如何使用反射获取字符串指针的变量名?

我想通过反射获取字段名称的名称。我将字符串作为指针传递,然后我想在函数中检索变量名称。typeFooBarstruct{foo*string}funcbar(s*string){varnamestring//TODO:Getnameofthefieldthatsispointingto!fmt.Println("Expectedstringisfoo:"+name)}funcmain(){f:=Foo{"bar"}bar(f.s)}我尝试通过以下方式获取s的值val:=reflect.ValueOf(s)然后我无法获取变量名。我应该提到我的结构中有多个字段,我事先不知道哪个字段有问题。

pointers - 函数指针参数变化

我正在尝试编写一些使用指针参数更改结构片段的函数。我在GoPlayground中用这种类型的代码做了一些Playground,我发现我有一些错误,但我不知道什么是管理它的最佳方法packagemainimport"fmt"typePersonstruct{namestring}funcdoSomething(person*Person){person.name="John"}funcmain(){varpersons[]Personp:=Person{name:"David"}persons=append(persons,p)doSomething(&p)fmt.Println(per