草庐IT

智能指针

全部标签

go - 如果函数将 slice 的元素复制到变量,它是使用指向该元素的指针还是副本?

示例情况:有一个全局结构保存了一个结构片段。typestctUserstruct{userstringprivilegeintcreatedtime.Time}typestctAllUsersstruct{sync.RWMutexslcUsers[]stctUser}varstrctAllUsersstctAllUsers有一个函数想要对用户进行操作,为了减少它锁定那个全局结构的时间,我想捕获一个用户并释放锁varstrctUserTempstctUserstrctAllUsers.RLockfora:=rangestrctAllUsers.slcUsers{iftmpName==st

go - 在NewX函数上返回指针背后有充分的理由吗?

这个问题已经有了答案:WhyshouldconstructorofGoreturnaddress?1答Pointersvs.valuesinparametersandreturnvalues3答在结构的“构造函数”上返回指针是否有充分的理由?例如:typeMyTypestruct{}funcNewMyType()*MyType{varm*MyTypereturnm}VStypeMyTypestruct{}funcNewMyType()MyType{varmMyTypereturnm}在大多数情况下,“构造函数”接受一些参数并返回指向类型的指针。为什么不返回一个值呢?提前谢谢。

go - 获取 slice 中值的指针

有什么办法可以得到指向slice中实际值的指针吗?我在map中有一棵优惠树:map[uint64]map[uint16][]offer为了通过id(从1到n)快速访问,我需要一片指针:[]*offer实际报价位于第一棵树中,slice中应该是指向实际报价的指针。我不能遍历树并收集实际值的指针,因为这个slice的range给我一个副本,但我总共有超过数十亿个这样的结构,副本会导致浪费我的内存:一个结构的40个字节会导致100+gb以及future更多。我还需要在树中存储连续的值片段,以便事实查找报价。可能有一些方法可以使用unsafe或reflect包来获取这些指针?指针索引只构建一次

optimization - 如何在 Golang 中获取指向任何数据类型值的字节指针?

我已经设法让以下函数在Go中运行。但是我想优化/概括代码,这样这个函数就会返回一个指向我传递给函数的任何值的第一个字节的指针。目前它只适用于[]uint32,但我想用它来获取起始内存地址作为许多其他类型(即byte[]、int[]、string等)的*byte。是否有更通用的方法来执行此操作,而不是将我需要处理的每一种类型都捕获为case语句?转到以下代码的Playground链接:https://play.golang.org/p/KtNTbERQGapackagemainimport("fmt""reflect""unsafe")funcToBytePointer(datainte

go - 如何将指针的值从映射传递到函数参数

所以我的用例是这样的:1。生成指向结构(汽车)的指针映射2。变异图3。迭代映射并传递给函数typeCarstruct{ModelstringSizeint}funcgetSize(carCar){fmt.Println(car.Size)}funcmain(){cars:=make(map[string]*Car)//fillcarswithstuffcars["Toyota"]=&Car{Model:"Toyota",Size:2,}for_,car:=rangecars{cars["Toyota"].Size=4}for_,car:=rangecars{//somehowgetth

arrays - Go 如何保证元素指针对数组和 slice 有效?

当你在数组或slice上使用索引器作为返回时,你会得到变量,这样你就可以获取它的地址。我想知道这是怎么可能的,因为数组/slice可能比目标变量嵌套得更多://ptrdeclarationhere{//arraydeclarationhereptr=&array[0];}在数组的情况下,我看到一个问题,数据在堆栈上,有slice,在堆上分配它并不能自动解决问题,因为GC可以删除整个slice,除非获取元素的地址链接到slice本身(从而防止释放内存)。示例:当不能保证指针的有效性时会发生什么——假设我的数组是颜色的集合。我选择一个元素,获取它的地址,整个数组被删除(因为它超出了范围),

go - 为什么我不能使用 flag.StringVar 将指针传递给 fmt.Println?

我已经开始研究Golang,并按照一个示例来传递命令行参数,我得到了以下代码:packagemainimport("flag""fmt")funcmain(){wordPtr:=flag.String("namestring","stringvalue","Passinastring")numPtr:=flag.Int("number",11,"Passinanint")boolPtr:=flag.Bool("switchflag",false,"Passinabool")varsvarstringflag.StringVar(&svar,"svar","svarstringvalue

pointers - 无法从指针接收器访问值

我无法从Pointer接收器获取值。它不断返回内存地址。我正在尝试以下面的格式访问来自其他文件的指针接收器的值packagetypesimport(//"Someproductrelatedimports""golang.org/x/oauth2""time")typeTestContextstruct{userIdstring}func(cont*TestContext)GetUserId()string{returncont.userId}我正在尝试通过多种方式解决它,但要么获取内存地址、nil值,要么出错。 最佳答案 始终编写

go - panic ()与结构与指针的含义?

使用大型结构调用panic(x)与使用指向该结构的指针调用panic(&x)有什么含义(如果有的话)?您传递给panic的interface{}是否在每次堆栈展开一个级别时都被复制,或者是否有其他魔法在发生?编辑:这可能很重要的一个例子是在http.Serve中,它将从任何panic中恢复并提供合适的消息。如果我对一个非常大的结构感到panic,这可能会对性能产生一些影响,因为堆栈框架展开并导致我的网络服务器过度负载。 最佳答案 这取决于panic的执行次数、值或指针参数、struct的大小等。在Go中,参数是按值传递的。接口(in

json - 将指针转换为其在 json 解码器中的主要值

如何将*string转换为string?这是我的错误代码:cannotusem.Body(type*string)astypestringinargumenttostrings.NewReader这是我的代码:dec:=json.NewDecoder(strings.NewReader(m.Body)) 最佳答案 取消引用指针以从*string获取string的值,然后在strings.NewReader函数中使用它。例如:-strValue:=*m.Bodydec:=json.NewDecoder(strings.NewReade