草庐IT

TIME_SLICE

全部标签

go - 如何以一种方式对数组/slice 进行排序

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭5年前。Improvethisquestion我有以下代码并问我自己这是解决以下要求的“方法”。我需要打印一个按文件时间排序的目录树。packagemainimport("fmt""github.com/kr/fs""os""time""sort")typefileinfostruct{Pathstringagetime.Duration}funcmain(){fmt.Print("testrangeoffs")walker:=fs.

Go Lang-将结构附加到 slice

是否可以将struct附加到slice?任何人都可以张贴一个例子吗?此slice需要具有struct值。testSlice=make([]Row,10)我试过用这种方式追加,但没有用。testSlice.append(row) 最佳答案 testSlice=append(testSlice,Row{/*...*/}) 关于GoLang-将结构附加到slice,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c

pointers - 函数调用后删除的 slice 内容

这个问题在这里已经有了答案:MyobjectisnotupdatedevenifIusethepointertoatypetoupdateit(3个答案)关闭4年前。这是我试图理解和改变的golang行为:我写了一个方法来在Golang中用slice填充结构。它在方法本身内工作,但slice内容在方法之外丢失。但是我想保留内容。这可能是因为在populateslice方法的末尾删除了slice内的指针,但我应该如何编写它以防止这种情况发生,即。在函数调用后保留mystruct.myslice中的内容?下面是我写的代码:typeBBDatacolumnstruct{Data[]strin

go - 如何使用反射获取 slice 数据?

packagemainimport("fmt""reflect")//AuthRequeststructtypeAuthRequeststruct{Idint64}funcmain(){//AuthRequestauth1auth1:=AuthRequest{Id:1111,}//Authrequestauth2auth2:=AuthRequest{Id:2222,}//createslicevarsliceModel=make([]AuthRequest,0)//putelementtoslicesliceModel=append(sliceModel,auth1)sliceMode

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

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

memory - Go: time.sleep 和内存使用

当运行下面的代码时,程序从1.5M左右开始,然后逐渐增长到6.4M。我想知道为什么。删除time.sleep可解决此问题。有没有办法在默认情况下使用for-select模式并在默认情况下休眠一段时间而不更改任何内存?在sleep后调用runtime.GC()确实可以解决问题。我们可以在不调用GC的情况下实现同样的事情吗?packagemainimport("time")funcmain(){c:=make(chanstruct{})for{select{case同上:packagemainimport("time")funcmain(){c:=make(chanstruct{})for

go - 获取 slice 中值的指针

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

arrays - 戈朗 : Is this an acceptable way to create a Slice from part of another Slice?

我四处搜索并没有找到另一个这样做的例子,但我无意中发现我能够通过简单地将另一个slice的片段传递给接受slice并返回它的函数来从另一个slice的片段创建一个sliceslice。例子:packagemainimport"fmt"funcmakeSliceFrom(s[]int)[]int{returns}funcmain(){s:=[]int{1,2,3,4,5,6,7,8,9,10}newS:=makeSliceFrom(s[1:7])fmt.Println(newS)}我不是在问这是否有效,因为我知道它有效并且似乎运作良好,我是在问这是否得到支持或有一些我不知道的不可预见的成

go - 我可以在 slice 中内联声明接口(interface)列表吗?

packagemainimport("fmt")funcmain(){varaAvarbBfor_,v:=range[]WhatAreYou{a,b}{fmt.Println(v.Question())}}typeWhatAreYouinterface{Question()string}typeAstruct{string}typeBstruct{int}func(aA)Question()string{return"I'manA"}func(bB)Question()string{return"I'maB"}上面的代码如我所料地工作,并按预期在每个接口(interface)上调用函数

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

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