草庐IT

stack-pointer

全部标签

pointers - 复制或传递指针

我看到了在getter和setter中使用以下内容的建议,即在设置值时传递指针以更改原始数据,但在获取值时不需要。如果是getter,没有指针,则复制值。我的问题是,复制对象以从中获取值(value)不是很低效吗,我们不能也使用指针吗?typeFoostruct{Bodystring}func(fooFoo)GetBody()interface{}{returnfoo.Body}func(foo*Foo)SetBody(bodystring){foo.Body=body} 最佳答案 您从哪里看到建议使用非指针接收器作为getter的

pointers - 对golang for循环的迭代值有点迷惑

这个问题与this有关和thisanswer除了一件小事,所有这些问题和答案对我来说都很有意义。如果for循环的第二个值是a[i],那么for循环的a[i]和a[i]有什么不同>当我们写的时候?看起来是一样的,但其实不是,对吧?请帮我解决这个问题。谢谢大家! 最佳答案 当你写的时候:a:=make([]int,3)a[0],a[1],a[2]=1,2,3fori,val:=rangea{println(a[i],"vs.",val)println(&a[i],"vs.",&val)}变量val被分配了a[i]中值的副本。基本上和这样

pointers - 指针变量的地址何时更改?

考虑thefollowingexample并注意指针变量a的位置如何保持固定,如预期的那样:vara*intv1:=1v2:=2a=&v1fmt.Printf("%p\n",&a)//output:0x1040c128a=&v2fmt.Printf("%p\n",&a)//output:0x1040c128现在考虑以下结构定义:typefoostruct{barint}如果a被声明为指向foo的指针变量,如thisexample,它在内存中的位置不会保持不变。vara*foov1:=foo{bar:1}v2:=foo{bar:2}a=&v1fmt.Printf("%p\n",a)//o

pointers - Go 中指向结构或数组值的指针如何工作?

考虑以下Go结构:typePersonstruct{NamestringAgeintCountrystring}我遇到过无数次以下用法:p:=&Person{"Adam",33,"Argentina"}但我看不出指向结构值有什么意义,我想知道它与以下内容有何不同:n:=&999//Error我的问题是:怎么可能指向一个值,即使它是一个结构或数组而不是像字符串或int这样的基本类型?奇怪的是,以下内容对我的理解没有帮助:fmt.Println(p,&p)//outputs:&{Adam33Argentina}0xc042084018为什么程序员要通过指针声明结构实例?这样做你能取得什么成

pointers - go中的form参数为map时,传入的是什么?

当形参为map时,直接给形参赋值并不能改变实参,但是如果给形参增加新的key和value,函数外的实参也是可以看到的。这是为什么?看不懂下面代码的输出值,形参和实参不一样。uncmain(){t:=map[int]int{1:1,}fmt.Println(unsafe.Pointer(&t))copysss(t)fmt.Println(t)}funccopysss(mmap[int]int){//pointer:=unsafe.Pointer(&m)//fmt.Println(pointer)m=map[int]int{1:2,}}stdout:0xc000086010map[1:1]

pointers - golang中slice的地址

我有这段代码packagemainimport("fmt")funcExtend(slice[]int,elementint)[]int{n:=len(slice)ifn==cap(slice){//Sliceisfull;mustgrow.//Wedoubleitssizeandadd1,soifthesizeiszerowestillgrow.newSlice:=make([]int,len(slice),2*len(slice)+1)copy(newSlice,slice)slice=newSlice}slice=slice[0:n+1]slice[n]=elementretur

pointers - 在 Go 中使用 unsafe.Pointer 引起 panic

代码是:packagemainimport("fmt""unsafe")typePointstruct{xintyint}funcmain(){buf:=make([]byte,50)fmt.Println(buf)t:=(*Point)(unsafe.Pointer(&buf))t.x=10t.y=100fmt.Println(buf)}运行时,出现运行时panic:panic:runtimeerror:invalidmemoryaddressornilpointerdereference[signal0xbcode=0x1addr=0xapc=0x43dd4d]为什么?

pointers - 附加到其他 slice 内的结构上的 slice 不持久

例如:packagemainimport"fmt"typeTeststruct{elems[]string}funcmain(){initial:=Test{elems:make([]string,0),}initial.elems=append(initial.elems,"apple")fmt.Println(initial.elems)//#1[apple]s:=make([]Test,0)s=append(s,initial)initial.elems=append(initial.elems,"bannana")fmt.Println(initial.elems)//#2[a

pointers - 如何将接口(interface)转换为结构

这是缓存的简化代码。假设Container放在一个包中,所以它不知道Member。虽然我想在Container中存储Member的实例,但我在Container中存储了一个空的Member实例作为outerType。在Container->GetMysql中,我用测试值填充一个新变量(但在现实世界中,它是动态地用数据库数据填充的)。然后在函数Put中,我将数据存储在项目中作为缓存以备下次使用。在Get中,我获取存储在项目中的数据。在此之前一切都很好。我的问题是我想将Get的结果转换为Memberm=res.(Member)的类型。如何将其转换为Member的实例我发现了很多关于这个主题

pointers - 包含级联映射的结构的空括号初始化

我有以下数据结构。它是一个结构链,每个结构都有map[string]T。基本上我将一个复杂的yaml文件序列化为一个数据结构。我有两个版本可以工作,但一个不能,我不清楚为什么?根据我的理解,Go编译器非常聪明,所以它应该找出需要分配对象的位置。请考虑下面的代码。typeUserDatastruct{UsernamestringPasswordstring}typeGroupsstruct{usersmap[string]UserData}typeClusterstruct{Groupmap[string]Groups}typeDirectorstruct{Clustermap[stri