網(wǎng)站首頁 編程語言 正文
前言
開發(fā)中經(jīng)常會(huì)遇到需要比較兩個(gè)slice
包含的元素是否完全相等的情況,在golang
中是不能夠直接通過 ==
來判斷兩個(gè)切片是否相等的,我們通常會(huì)通過兩種方法去比較切片是否相等,這里通過幾個(gè)示例來看一下這兩種方法,感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。
判斷兩個(gè)[]byte是否相等
因?yàn)樵?code>bytes標(biāo)準(zhǔn)庫中提供了[]byte
的比較方法,所以我們不再需要重復(fù)造輪子了;示例如下:
package main import ( "bytes" "fmt" ) func main() { a := []byte{1,2,3} b := []byte{1,2} c := []byte{1,2,3} fmt.Println(bytes.Equal(a,b)) fmt.Println(bytes.Equal(a,c)) }
執(zhí)行代碼輸出如下:
使用reflect判斷slice是否相等
我們還可以借助reflect包的reflect.DeepEqual方法來比較兩個(gè)切片是否相等。這個(gè)寫法很簡(jiǎn)單:
// ReflectDeepEqual 直接使用 reflect 包的 reflect.DeepEqual 方法進(jìn)行比較 func StringSliceReflectEqual(a, b []string) bool { return reflect.DeepEqual(a, b) }
手寫循環(huán)遍歷比較
我們都知道Golang中reflect效率很低,使用reflect通常需要付出性能代價(jià),如果我們確定了slice的類型,那么自己實(shí)現(xiàn)slice的相等判斷相對(duì)來說也不是那么麻煩:
// LoopCompare 循環(huán)遍歷比較 // 先比較兩個(gè)數(shù)的長(zhǎng)度是否相等 // 再循環(huán)遍歷每一個(gè)元素進(jìn)行比較 func LoopCompare(a, b []int) bool { if len(a) != len(b) { return false } //與reflect.DeepEqual的結(jié)果保持一致:[]int{} != []int(nil) if (a == nil) != (b == nil) { return false } for i, v := range a { if v != b[i] { return false } } return true }
性能比較
借助Benchmark來簡(jiǎn)單的測(cè)試比較下二者的性能。
package test import ( "reflect" "testing" ) var ( testA = []int{1,3,5,9,11,13} testB = []int{1,3,5,9,11,13,17,23} ) // BenchmarkReflectDeepEqual 測(cè)試 reflect.DeepEqual 效率 func BenchmarkReflectDeepEqual(b *testing.B) { for n := 0; n < b.N; n++ { ReflectDeepEqual(testA, testB) } } // BenchmarkLoopCompare 測(cè)試 循環(huán)比較 效率 func BenchmarkLoopCompare(b *testing.B) { for n := 0; n < b.N; n++ { LoopCompare(testA, testB) } }
在測(cè)試文件所在目錄執(zhí)行go test -bench=.
命令
Benchmark對(duì)比測(cè)試結(jié)果:
根據(jù)測(cè)試結(jié)果我們可以得到:
- 使用reflect的方式,649 ns完成一次操作;
- 使用循環(huán)遍歷的方式,12.7 ns完成一次比較,效率對(duì)比十分明顯。
原因在于reflect 接收任意類型的參數(shù),方法內(nèi)部要對(duì)類型做判斷;循環(huán)遍歷僅支持已知固定類型,效率自然要高些。所以就只能忍痛放棄reflect了。
總結(jié)
以上就是整理的golang 判斷 兩個(gè)slice 是否相等全部?jī)?nèi)容,我們可以借助reflect包的reflect.DeepEqual方法來比較兩個(gè)切片是否相等,但是效率比較低,如果我們確定了slice的類型,我們可以手寫遍歷循環(huán)的方式來比較,相對(duì)效率比較高,希望文章能夠幫你解決golang 判斷 兩個(gè)slice 是否相等所遇到的程序開發(fā)問題。
原文鏈接:https://juejin.cn/post/7167584927976783880
相關(guān)推薦
- 2022-03-16 Linux環(huán)境下安裝nginx教程_nginx
- 2022-01-18 django中ajax發(fā)送post請(qǐng)求報(bào)403錯(cuò)誤csrf禁止,解決只需三步
- 2022-09-16 深度學(xué)習(xí)中shape[0]、shape[1]、shape[2]的區(qū)別詳解_python
- 2022-07-03 Android實(shí)現(xiàn)翻頁特效_Android
- 2022-09-08 pandas刪除部分?jǐn)?shù)據(jù)后重新生成索引的實(shí)現(xiàn)_python
- 2022-06-08 Spring Cloud Openfeign分析
- 2022-09-29 react嵌套路由實(shí)現(xiàn)TabBar的實(shí)現(xiàn)_React
- 2022-09-05 用兩個(gè)隊(duì)列模擬一個(gè)棧
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支