1. 程式人生 > >golang中比較2個slice

golang中比較2個slice

這是用雙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