草庐IT

C++ 霍夫曼树和指针

全部标签

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

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

Go:需要设置属性但没有指针接收器?

packagemainimport"fmt"typeMyClassstruct{datastring}func(thisMyClass)MyMethod(){this.data="Changed!"}funcmain(){obj:=MyClass{}obj.MyMethod()fmt.Println(obj)}我需要通过MyMethod()更改data属性,但我无法将接收器类型更改为指针(func(this*MyClass))因为它必须满足接收者不是指针的接口(interface),是否可以通过其他方式实现? 最佳答案 您需要使用指

interface - Go:工厂返回指针和接口(interface){}类型

考虑以下工厂:GoplaygroundtypeTypeAstruct{placeholderint}funcNewTypeA()*TypeA{returnnew(TypeA)}funcmain(){factory:=make(map[string]func()interface{})factory["TypeA"]=NewTypeA}这给了我以下错误:cannotuseNewTypeA(typefunc()*TypeA)astypefunc()interface{}inassignment这很清楚。我认为interface{}可以与指针匹配。我找到了这个解决方案:Goplaygroun

go - 关于Golang指针,这是为什么呢?

发生了什么?varninterface{}=2varpn=&nvarpf=(*int64)(unsafe.Pointer(pn))fmt.Println(pf)fmt.Println(pn)fmt.Println(*pn)//2fmt.Println(*pf)//not2*pf=9fmt.Println(*pn)//errorinvalidmemoryaddressornilpointerdereferencefmt.Println(*pf)//9我的问题是为什么*pf不等于*pn和错误?感谢您的回复。 最佳答案 n属于interf

go - 写入指针但编译器仍然提示未使用的变量

以下代码会导致编译错误:main.go:8:9:pdeclaredandnotusedpackagemainfuncmain(){pointers:=make([]*int,5)a:=1//createanintfor_,p:=rangepointers{p=&a}}写入p不算使用吗? 最佳答案 P的作用域仅限于循环block,每次通过循环时,本质上都会获取pointersslice元素的副本。这虽然可行:packagemainimport"fmt"funcmain(){pointers:=make([]*int,5)a:=1//c

go - sync.Pool 新函数中是否需要返回指针类型?

我看到了issue在Github上说sync.Pool应该仅与指针类型一起使用,例如:varTPool=sync.Pool{New:func()interface{}{returnnew(T)},}有意义吗?returnT{}怎么样,哪个是更好的选择,为什么? 最佳答案 sync.Pool的全部意义在于避免(昂贵的)分配。大型缓冲区等。您分配一些缓冲区,它们保留在内存中,可供重用。因此使用指针。但在这里,您将在每一步都复制值,从而违背了目的。(假设您的T是一个“普通”结构,而不是像SliceHeader这样的东西)

api - golang json 解码中的指针

我正在尝试使用以下命令解码网络服务响应,它工作正常。bodyBytes,_:=ioutil.ReadAll(response.Body)bodyString:=string(bodyBytes)err=json.Unmarshal([]byte(bodyString),&output)fmt.Println(&output)当我使用指针变量“&output”时,它工作正常,即;输出正确显示。但是当我尝试在不使用&(&符号)的情况下直接使用变量时,输出看起来不太好。bodyBytes,_:=ioutil.ReadAll(response.Body)bodyString:=string(b

arrays - Go 中的不安全指针 : function call end kills array

我正在编写一个库,我想向调用方返回一个非特定类型的数组(或写入一个数组)。类型可能会有所不同,具体取决于调用者-但是,我可以从我的函数中创建尽可能多的所述类型的对象。一种方法是调用者创建一个数组,然后被调用者填充它——但是,没有办法告诉这个数组将有多长。(有没有办法让被调用者使调用者的数组更大?记住,被调用者只能看到xinterface{}...)我选择的另一种方式是因为我看不到上面的可能性,调用者给我他特定类型的指针,我将它重定向到我创建的对象数组。下面是我的解决方案。我的问题:为什么函数调用后数组为空?他们在我操作后指向同一个数组,他们应该是一样的。我忽略了什么吗?我考虑过GC,但

将指针或副本的参数传递给函数

我正在考虑Go指针,通过值或引用将变量作为参数传递给函数。在一本书中,我遇到了一个很好的例子,它是下面的第一个代码片段,是关于传递指针的。第一个版本按预期工作,在采用指针参数的函数中对变量本身进行更改,而不是对其副本进行更改。但是下面的第二个例子我正在修改它的副本。我认为它们的行为应该相同,第二个是处理作为参数传递的变量,而不是它的副本。本质上,这两个版本的函数有什么不同?versioninthebook,通过引用传递参数:packagemainimport("fmt")//simplefunctiontoadd1toafuncadd1(a*int)int{*a=*a+1//wecha

go - 如何在 GO 的全局范围内存储和获取指针引用

我有以下代码:packagemainfuncmain(){//createapointerrefereceofsessionofMongoDBsession:=mongoDB.CreateSession()//Question1:Howtostoreapointerreferenceinaglobalscopeandusinganywhereofthecodedefersession.Close()//NoteIsupposethatthecodecalltohandlermethodsthatcalltotheProcessinthepackagecontroller(thelast