这是用双for的方法实现了2个slice的比较,方法很土,但思路直观
// FuncTest project main.go package main import ( "fmt" ) //检查slice b是否在slice a中 //需要比对的2个slice分别是a和b //isSame 比对的2个slice是否相同 //diffSlice 如果2个slice不同,那么不同的元素将储存在其中 func checkSliceBInA(a []string,b []string) (isIn bool,diffSlice []string) { lengthA := len(a) for _,valueB := range b { temp := valueB //遍历取出B中的元素 for j := 0; j < lengthA; j++ { if temp == a[j] { //如果相同 比较下一个 break } else { if lengthA == (j + 1) { //如果不同 查看a的元素个数及当前比较元素的位置 将不同的元素添加到返回slice中 diffSlice = append(diffSlice,temp) fmt.Println("---->",diffSlice) } } } } if len(diffSlice) == 0 { isIn = true } else { isIn = false } return isIn,diffSlice } func main() { sliceA := []string{"1","2","3"} sliceB := []string{"2","3"} isIn,diffSlice := checkSliceBInA(sliceB,sliceA) fmt.Println(isIn,diffSlice) //输出 false [1] }
不好的地方在于:
1 2个slice是有顺序的,参数顺序不一样结果也不一样
2 传入的slice是固定的
网上有人这么写func In_slice(val interface{},slice []interface{}) bool { for _,v := range slice { if v == val { return true } } return false }<pre name="code" class="plain">func Slice_diff(slice1,slice2 []interface{}) (diffslice []interface{}) { for _,v := range slice1 { if !In_slice(v,slice2) { diffslice = append(diffslice,v) } } return }在gitHub上有人实现了更牛叉的,传送门https://github.com/fatih/set 原文链接:https://www.f2er.com/go/190505.html