Golang 使用Map實(shí)現(xiàn)去重與set的功能操作
假設(shè)現(xiàn)在有一個(gè)需求
將以下 url 保存起來,要求不重復(fù)
www.baidu.com www.sina.com.cn www.hao123.com www.baidu.com www.hao123.com
可以利用 map 的 key 唯一性的問題處理
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ù)量
可以手寫暴力寫入測(cè)試
package main
import (
"fmt"
)
var test = map[int]int {
}
func main() {
for i := 0; i < 10000000; i++ { // 測(cè)試對(duì)1000萬key的支持,完美支持
fmt.Println(i)
test[i] = i
}
}
補(bǔ)充:golang map/set類型
map類型
1. 基礎(chǔ)特性
map是一種無序的鍵值對(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() {
// 通過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. 元素訪問
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沒有內(nèi)置Set類型, 可以自定義實(shí)現(xiàn)。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
詳解Go語言Sync.Pool為何不加鎖也能夠?qū)崿F(xiàn)線程安全
在這篇文章中,我們將剖析sync.Pool內(nèi)部實(shí)現(xiàn)中,介紹了sync.Pool比較巧妙的內(nèi)部設(shè)計(jì)思路以及其實(shí)現(xiàn)方式。在這個(gè)過程中,也間接介紹了為何不加鎖也能夠?qū)崿F(xiàn)線程安全,感興趣的可以學(xué)習(xí)一下2023-04-04
Go語言測(cè)試庫testify使用學(xué)習(xí)
這篇文章主要為大家介紹了Go語言測(cè)試庫testify的使用學(xué)習(xí)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
go-zero數(shù)據(jù)的流處理利器fx使用詳解
這篇文章主要為大家介紹了go-zero數(shù)據(jù)的流處理利器fx使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
Gorm存在時(shí)更新,不存在時(shí)創(chuàng)建的問題
這篇文章主要介紹了Gorm存在時(shí)更新,不存在時(shí)創(chuàng)建的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08
解決golang時(shí)間字符串轉(zhuǎn)time.Time的坑
這篇文章主要介紹了解決golang時(shí)間字符串轉(zhuǎn)time.Time的坑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-04-04
Go開發(fā)go-optioner工具實(shí)現(xiàn)輕松生成函數(shù)選項(xiàng)模式代碼
go-optioner?是一個(gè)在?Go?代碼中生成函數(shù)選項(xiàng)模式代碼的工具,可以根據(jù)給定的結(jié)構(gòu)定義自動(dòng)生成相應(yīng)的選項(xiàng)代碼,下面就來聊聊go-optioner是如何使用的吧2023-07-07

