草庐IT

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

全部标签

pointers - 在 Go 中增加一个指针

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

go - 如何将字符串作为参数传递给 Golang 指针接收函数?

这个问题在这里已经有了答案:"usedasvalue"infunctioncall(1个回答)关闭4年前。我正在尝试一种带有值和指针接收函数的简单Go结构。我无法将一个字符串作为参数传递给指针接收函数来修改结构数据。任何人都可以帮忙吗?代码:packagemainimport("fmt")typebookstruct{authorstringnamestringcategorystringpriceint16}func(bbook)greet()string{return"Welcome"+b.author}func(b*book)changeAuthor(authorstring){

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)我做错了什么?函数的输出已定义,不知道为什么会出

go - 我可以使用指向 "error"的指针来捕获返回错误吗?

我正在编写一些事务开始/提交/回滚函数,我想将block配对以防止忘记提交我是这样写的:func(foo*Foo)Bar()(errerror){foo.Begin()deferfoo.End(&err)//somebusinesscodereturn}func(foo*Foo)End(eptr*error){//ifrecoverifr:=recover();r!=nil{debug.PrintStack()*eptr=r.(error)}varerr=*eptriferr!=nil{foo.Rollback()}else{foo.Commit()}}它有效,但它使用“接口(inte

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字符串。这是怎么回事?

go - Golang 接口(interface)上的指针接收器和值接收器

这个问题没有我想的那么清楚我会问一个更好的问题。但我不想在上面标记重复。所以我提出了我自己的问题。如果您可以帮助将其删除,以免混淆社区。请只做那些需要的。请不要对我投反对票。抱歉不清楚我是golang的新手,刚刚掌握它的窍门。我正在学习围棋之旅,然后根据自己的理解使用它。我在Interfaces,开始用自己的理解去实现。这是GoPlayGroundLink第1步:我创建了3种类型:int、struct和interfacepackagemainimport("fmt")typeMyIntinttypePairstruct{n1,n2int}typetwoTimeableinterface

GO语言如何改变 map 指针内部对象的值

我该怎么做?我有对象列表,我想列出所有对象并更改对象名称。我有列表,我正在做一段时间发送到另一个函数,在那里我更改了名称,但名称没有保存。知道我该怎么做吗?https://play.golang.org/p/el3FtwC-3U如果有任何我可以阅读以了解更多信息的书籍,请。谢谢你帮助我=D 最佳答案 在范围循环中:for_,track:=rangetracks{//sendtracktochanneltochangethenameWorking(&track,&c)}track变量实际上是映射中包含的值的副本,因为这里的赋值作用于T

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

go - 具有指针类型接收器的方法不会在反射中列出

我试图通过使用反射来调用一个类型的所有方法来概括我的代码。它简单明了,但存在一个问题,reflection.TypeOf(T).NumMethods(或其他方法)忽略了使用接收器类型作为指针的方法。例如,这段小代码将打印1而不是2:packagemainimport("fmt""reflect")typeFoostruct{}func(fFoo)Bar(){}func(f*Foo)Baz(){}funcmain(){obj:=Foo{}fmt.Println(reflect.TypeOf(obj).NumMethod())}您可以在playground中运行.它打印1因为Bar方法。如