这是用双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
有疑问加站长微信联系(非本文作者)