分享
  1. 首页
  2. 文章

golang中比较2个slice

u012210379 · · 4993 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

这是用双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



有疑问加站长微信联系(非本文作者)

本文来自:CSDN博客

感谢作者:u012210379

查看原文:golang中比较2个slice

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
4993 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏