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) }