這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
這是用雙for的方法實現了2個slice的比較,方法很土,但思路直觀
// FuncTest project main.gopackage mainimport ("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