草庐IT

指针和数组的笔试题

全部标签

mysql - 指向 MySQL 查询抽象接口(interface)的指针片段

我正在尝试抽象我对MySQL数据库的使用,但我遇到了一个错误。我将以对象为例:packagemodels//Product:TheProduct'smodeltypeProductstruct{IDintNamestringPriceintPictureURLstring}我将尝试在我的数据库中检索产品id=1。为此,假设我已经连接到我的数据库,该连接由下一个变量表示:vardatabaseMySQL*sql.DB为了查询我的数据库,我使用了这个函数://QueryMySQLqueryourMySQLdatabasefuncQueryMySQL(sqlquerymodel.SQLQue

Golang结构体指针调用接口(interface)方法

我正在学习Golang,但在遍历链表时遇到了问题。我打算做的是访问链表的所有节点,并从每个节点调用一个接口(interface)方法。我已经定义了一个接口(interface)typeSortableinterface{CompareTo(tSortable)int}我已经定义了一个节点类型和一个链表typenodestruct{pNext*nodevalueint}typeLinkedListstruct{PHead,PNode*node}func(nnode)CompreTo(tSortable)int{other:=t.(node)ifn.value==other.value{r

pointers - 为指针类型的字段赋值的简写是什么

这个问题在这里已经有了答案:HowdoIdoaliteral*int64inGo?(4个答案)关闭4年前。我成功了:packagemainimport"fmt"typeteststruct{A*intBstring}funcmain(){x:=1varAtestA.B="hello"A.A=&xfmt.Printf("%s,%v",A.B,*A.A)}Playground:https://play.golang.org/p/iMsFBTWkRJU我知道使用x:=1和A.A=&x已经结束了。如何修改并使其更简单?谢谢你的时间

pointers - Golang指针反向链表混淆

我是Golang的新手,对指针在这里的工作方式有点困惑,我以反向链表问题为例。funcreverseList(head*ListNode)*ListNode{varprev*ListNode=nilfor{ifhead==nil{break}temp:=headhead=head.Nexttemp.Next=prevprev=temp}returnprev}在这种情况下,temp和head指向相同的内存位置。但是,如果我将行temp.Next=prev放在head=head.Next之前,head.Next将指向nil。当我们说temp.Next=prev时,幕后发生了什么。我们是说t

python - 从 go 调用 python 回调指针

我收到这个错误:Tickertickedunexpectedfaultaddress0xb01dfacedebac1efatalerror:fault[signalSIGSEGV:segmentationviolationcode=0x1addr=0xb01dfacedebac1epc=0x105c4152e]goroutine17[running,lockedtothread]:runtime.throw(0x105c74358,0x5)/usr/local/go/src/runtime/panic.go:616+0x81fp=0xc420050d48sp=0xc420050d28p

go - 从 reflect.Type 中删除指针

我有一个reflect.Type,它包含一个指向结构的双指针。我希望能够删除一个间接级别以获得指向该结构的指针。这可能吗?例如,我想这样做:funcfoo(xinterface{}){typ:=reflect.TypeOf(x)fmt.Printf("%v",typ)//prints**FoorealType:=typ.PointsTo()fmt.Printf("%v",typ)//prints*Foo}但据我所知,这个功能并不存在。有一个Indirect函数在Value上运行,但我看不到任何类似的适用于Type的函数。 最佳答案

go - 类型 INode* 是指向接口(interface)的指针,而不是接口(interface)

所以今天第一次尝试go并不断遇到与接口(interface)有关的错误,我想我没有正确理解它们。我试着四处寻找答案,但我习惯使用的术语与其他语言略有不同,所以我无法将它们拼凑起来。作为实践,我决定实现一个非常简单的链表,但我收到的错误是:typeINode*ispointertointerface,notinterface当调用.setNext(node*Inode)这背后的原因是什么?我在界面中缺少哪些信息?这是不完整的实现:packagemaintypeobjectinterface{}typeINodeinterface{GetData()objectGetNext()*INod

go - 为什么 Go 对数组的范围循环有运行时开销?

我希望对数组元素进行范围迭代不会带来任何运行时开销,但它似乎比原始数组访问慢8倍:funcBenchmarkSumRange(b*testing.B){nums:=[5]int{0,1,2,3,4}forn:=0;n基准输出:BenchmarkSumRange-810000000002.18ns/opBenchmarkSumManual-820000000000.28ns/op如果它是一个长度在编译时未知的slice而不是一个数组,这可能是有意义的,在这种情况下,运行时代码必须涉及一个带有边界检查的循环。但对于在编译时已知大小的数组,考虑到开销很大,编译器可以将范围迭代替换为手动访问。

go - 递归扩展包含指针的结构定义

这个问题基于以下内容:goreflectiondeeplyinstruct我需要同样的东西-扩展结构定义以将其作为JSON对象传递,但唯一的区别是结构包含指向另一个结构的指针。因此,提供的代码无法处理。我尝试通过以下方式修改它:funcprintFields(prefixstring,treflect.Type){fori:=0;i但是在指针的情况下它会陷入panic。如何解决?编辑:得到了我需要的:funcprintFields(prefixstring,treflect.Type){ift.Kind()!=reflect.Struct{return}fori:=0;i

go - 填充作为指针传递给函数的结构数组

我想使用GoogleCloudPlatformDatastore进行数据分页,我在GCP的页面(https://cloud.google.com/datastore/docs/concepts/queries)上找到了一个使用Cursors进行分页的示例,它工作得非常好。Google提供的示例对变量vartasks[]Task和vartaskTask进行了硬编码,我想创建一个可重用函数,我可以在其中通过类型为interface{}的参数将指针传递给结构数组,并让该结构由该函数填充。例如:typeMyStruct1struct{F1string}typeMyStruct2struct{F