jjzjj

pointers

全部标签

pointers - 不同类型的指针之间有什么区别?

指针指向内存中的一个位置。据我所知,实际上所有内存地址都具有相同的类型,与变量类型无关。除了使用不同的指针类型(*int、*string等),是否可以只使用一种类型(varppointer)所有指针类型?不同的指针类型有什么区别?packagemainimport"fmt"funcmain(){i:=5s:="abc"varpi*int//alternativelyvarpipointervarps*string//alternativelyvarpspointerpi=&ips=&sfmt.Printf("%p%p",pi,ps)//resultis0x1040e0f80x1040a

pointers - 在 Go 中增加一个指针

这个问题在这里已经有了答案:PointerarithmeticinGo(2个答案)关闭6年前。谁能告诉我如何在Go中通过字符串递增指针?我已经像在C中那样尝试了ptr+=1但它说类型*string和int是不兼容的。谢谢

function - 在单独的 golang 包中声明一个结构不能返回值,但在具体声明时可以

尝试从另一个包中导入一个结构类型,它完美返回,但除非在不使用实例化函数的情况下声明,否则无法找到该结构的值。//Xexecutesandfindsvaluesfine,Zdoesnot.packagemainfuncmain(){x:=&Command{}z:=command.NewCommand()fmt.Println(x.command)fmt.Println(z.command)}packagecommandtypeCommandstruct{//Ourstructureddata/objectforCommandaliasstringcommandstringverboseb

pointers - 无法通过结构方法替换指针

得到一个返回指针的结构方法:func(d*DataMap)Get(pCoord)*CellData{return&d.Data[p.X+(p.Y*d.Size)]}d.Data是一个CellData数组,它是一个具有多个字段的结构。使用这种方法我可以修改每个字段的内部值,即:example.Get(p).Something=123但是我不能这样做:example.Get(p)=*yada(yadaisa*CellData)我想用我得到的另一个指针替换指针的地方:cannotassigntoexample.Get(p)(undefined)我做错了什么?函数的输出已定义,不知道为什么会出

pointers - golang 中的指针

这个问题在这里已经有了答案:Whydoesjson.Unmarshalworkwithreferencebutnotpointer?(4个答案)关闭4年前。我正在使用golang来解析一个json字符串:str:="{...}"varfinterface{}json.Unmarshal([]byte(str),f)fmt.Println(f)虽然我在控制台中得到了nil。当我将代码更改为:json.Unmarshal([]byte(str),&f)它将打印json字符串。这是怎么回事?

Cgo:如何将双数组从 C 返回到 Go

我有这样一个C函数double*c_func(intn_rows){doubleresult[n_rows];for(inti=0;i然后我使用这个Go函数来处理Cdouble://convertCdoublepointertofloat64slice...funcdoubleToFloats(in*C.double,lengthint)[]float64{out:=make([]float64,length,length)start:=unsafe.Pointer(in)size:=unsafe.Sizeof(C.double(0))fori:=0;i这有时有效但有时无效。当它不起作

pointers - 为什么Go允许将接口(interface)变量分配给未实现值接收者的值?

很抱歉,这个问题标题很混乱,但我有点不明白。在下面的代码中,当我们试图将x分配给p时会出现错误,因为x需要p来实现M(),而它没有,因为M()有指针接收器。typePersonstruct{NamestringAgeint}func(p*Person)M(){}typeIinterface{M()}funcmain(){varxIvarp:=Person{}x=p//Error,M()haspointerreceiver}这对我来说是有意义的。我不明白的是,在下面的示例中将x分配给&p是多么令人愉快。在本例中,M()有一个值接收器,而不是指针接收器,但它仍然可以正常工作。typePer

function - 指向函数参数中接口(interface) slice 的指针

我有以下功能:funcread(filePathstring,structure*[]interface){raw,err:=ioutil.ReadFile(filePath)iferr!=nil{fmt.Println(err.Error())os.Exit(1)}json.Unmarshal(raw,structure)}我这样调用它:indexes:=[]Indexread(path+"/"+element+".json",&indexes)但是,当我从函数声明中删除structure*[]interface时,我遇到了奇怪的错误,该错误消失了:./index.verb.go:7

pointers - 指向结构的指针更改未反射(reflect)在调用者中

我将一个指向结构的指针传递给另一个名为someFunc()的函数并在那里进行更改,但在本例中,它不会反映在调用方函数中。typeSlotstruct{f1intf2stringf3[]*string}funcNewSlot(f1,f2){return&Slot{f1:f1,f2:f2,f2:make([]*string,0)}}funcmain(){slots:=&Slots{}scanner:=bufio.NewScanner(os.Stdin)forscanner.Scan(){s:=scanner.Text()sarr:=strings.Split(s,"")fmt.Printl

pointers - 创建变量会创建一个副本,取消引用不会。为什么?

为什么将值放入变量会创建一个副本,但取消引用却不会?是编译器的简单优化,知道它可以只使用原始结构的地址,而创建变量总是分配新内存吗?示例1:x1:=&struct{xint}{x:0}y1:=*x1z1:=&y1z1.x++fmt.Printf("---1:\n%#v\n%#v\n",x1,z1)示例2:x2:=&struct{xint}{x:0}z2:=&*x2z2.x++fmt.Printf("---2:\n%#v\n%#v\n",x2,z2)在这里运行:https://play.golang.org/p/myugNmjrQFjgo文档中是否有描述此行为的部分?