Golang 使用Map實(shí)現(xiàn)去重與set的功能操作
假設(shè)現(xiàn)在有一個(gè)需求
將以下 url 保存起來(lái),要求不重復(fù)
www.baidu.com www.sina.com.cn www.hao123.com www.baidu.com www.hao123.com
可以利用 map 的 key 唯一性的問(wèn)題處理
package main var set = map[string]bool { } func main() { ... url := xxx if set[url] { // 表示集合中已經(jīng)存在 return } set[url] = true // 否則如果不存在,設(shè)置為true }
// 完成后,set的所有的key值為不重復(fù)的值
在此之前,需要確定 golang 支持的 map 的 key 數(shù)量
可以手寫(xiě)暴力寫(xiě)入測(cè)試
package main import ( "fmt" ) var test = map[int]int { } func main() { for i := 0; i < 10000000; i++ { // 測(cè)試對(duì)1000萬(wàn)key的支持,完美支持 fmt.Println(i) test[i] = i } }
補(bǔ)充:golang map/set類型
map類型
1. 基礎(chǔ)特性
map是一種無(wú)序的鍵值對(duì)的集合; 所以可以類似數(shù)組/slice一樣進(jìn)行迭代
map的值可以使內(nèi)建類型, 也可以是struct類型
內(nèi)部使用hash表實(shí)現(xiàn), map的hash表包含了一個(gè)collection of buckets(桶集合)
2. 聲明與初始化
package main import ( "fmt" ) // map[keyType]valueType func initMap() { // 通過(guò)make方法創(chuàng)建 dict := make(map[string]int) dict["age"] = 18 // 直接創(chuàng)建 dict2 := map[string]string{"name":"xiaoming", "phone":"135xxx"} dict2["addr"] = "Guangzhou" fmt.Printf("%v\n", dict2) } func main() { initMap() }
3. 元素訪問(wèn)
package main import ( "fmt" ) type Student struct { name string grade int } func useMap() { //使用前應(yīng)該先初始化, 否則panic報(bào)錯(cuò) // var map1 map[string]string // map1["a"] = "b" // will panic map1 := make(map[string]Student) map1["s1"] = Student{name:"xiaomo", grade:1} fmt.Printf("%v\n", map1) } func main() { useMap() }
4. 在函數(shù)中傳遞map
在函數(shù)間傳遞map對(duì)象, 是傳遞引用而不是拷貝; 因此在函數(shù)中對(duì)map進(jìn)行了修改, 引用到它的地方也會(huì)相應(yīng)修改
package main import ( "fmt" ) type Student struct { name string grade int } func useMap() { map1 := make(map[string]Student) map1["s1"] = Student{name:"xiaomo", grade:1} // 作為函數(shù)參數(shù)傳遞 printMap(map1) } func printMap(m map[string]Student) { fmt.Printf("currentMap: %v\n", m) } func main() { useMap() }
Set類型
golang沒(méi)有內(nèi)置Set類型, 可以自定義實(shí)現(xiàn)。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
Golang實(shí)現(xiàn)超時(shí)退出的三種方式
這篇文章主要介紹了Golang三種方式實(shí)現(xiàn)超時(shí)退出,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03基于golang時(shí)間轉(zhuǎn)換的問(wèn)題
下面小編就為大家?guī)?lái)一篇基于golang時(shí)間轉(zhuǎn)換的問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08Go?語(yǔ)言使用goroutine運(yùn)行閉包踩坑分析
這篇文章主要介紹了Go?語(yǔ)言使用goroutine運(yùn)行閉包踩坑解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11k8s容器互聯(lián)-flannel?host-gw原理篇
這篇文章主要為大家介紹了k8s容器互聯(lián)-flannel?host-gw原理篇,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04如何編寫(xiě)Go語(yǔ)言中間件的實(shí)例教程
不知道大家有沒(méi)有寫(xiě)過(guò)中間件呢,它是怎么寫(xiě)的呢?下面這篇文中就來(lái)給大家分享一下使用Go,如何編寫(xiě)中間件,文中通過(guò)示例代碼介紹的非常詳細(xì),供大家參考學(xué)習(xí),下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-04-04