golang list slice 删除其中一项比对

前端之家收集整理的这篇文章主要介绍了golang list slice 删除其中一项比对前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

golang list slice 删除其中一项比对

转自:http://studygolang.com/articles/3221

slice可以动态添加项(使用append()函数),但是没有删除项的函数。变通方法,可以使用slice重新组合的方式删除一个或多个项,slice是引用类型,存的是指针,性能上不会有太多影响,示例如下:

package main

import "fmt"

func main() {
    s := []int{11,22,33,44,55,66} // 原始slice
    i := 2                             // 待删除项索引
    s = append(s[:i],s[i+1:]...)      // 最后面的“...”不能省略
    fmt.Println(s) // 数据结果  [11 22 44 55 66]
}


有人回答的很好:

这样是可以实现。不过从slice这种数据结构来看,本身并不适合做删除操作。抛开语言,只谈数据结构,我们知道数组删除是会移动元素的,效率会比较低。当然任何语言的数组实现(顺序存储),删除元素都避免不了移动元素。
所以,如果会平凡删除中间或开头的元素,更好的是选择链表这样的数据结构。Go中可以使用map或container/list包。


那咱就上个list的吧:

自己写一个contain函数,判断某value是否存在在list中

funcContains(l*list.List,valuestring)(bool,*list.Element){
fore:=l.Front();e!=nil;e=e.Next(){
ife.Value==value{
returntrue,e
}
}
returnfalse,nil}

那就直接掉remove接口呗


ifcontain,e:=Contains(l,"xxx");contain{
l.Remove(e)
}

猜你在找的Go相关文章