Go1.21新增maps包的用法詳解
maps.Clone
定義如下:
func Clone[M ~map[K]V, K comparable, V any](m M) M
返回 m 的一個副本,因為新的鍵和值是使用賦值方式復(fù)制的,所以這是一個淺克隆。簡單示例如下:
package main import ( "fmt" "maps" ) func main() { m := map[string]string{"foo": "bar"} m1 := maps.Clone(m) fmt.Println(m1) // map[foo:bar] }
maps.Copy
定義如下:
func Copy[M1 ~map[K]V, M2 ~map[K]V, K comparable, V any](dst M1, src M2)
復(fù)制 src 中的所有鍵值對并添加到 dst 中。當 src 中的鍵已經(jīng)在 dst 中存在時,dst 中的值將被 src 中被該鍵對應(yīng)的值覆蓋。簡單示例如下:
package main import ( "fmt" "maps" ) func main() { m := map[string]string{"foo": "bar", "foo2": "bar2"} m1 := map[string]string{"foo": "bar2", "foo3": "bar3"} maps.Copy(m1, m) fmt.Println(m1) // map[foo:bar foo2:bar2 foo3:bar3] }
maps.DeleteFunc
定義如下:
func DeleteFunc[M ~map[K]V, K comparable, V any](m M, del func(K, V) bool)
從 m 中刪除經(jīng) del 函數(shù)計算后返回 true 的所有鍵值對。簡單示例如下:
package main import ( "fmt" "maps" ) func main() { m := map[string]int{ "one": 1, "two": 2, "three": 3, "four": 4, } maps.DeleteFunc(m, func(k string, v int) bool { return v%2 != 0 }) fmt.Println(m) }
刪除所有值為奇數(shù)類型的鍵值對。
maps.Equal
定義如下:
func Equal[M1, M2 ~map[K]V, K, V comparable](m1 M1, m2 M2) bool
判斷兩個 map 是否包含相同的鍵值對。簡單示例如下:
package main import ( "fmt" "maps" ) func main() { m := map[string]string{"foo": "bar", "foo2": "bar2"} m1 := map[string]string{"foo": "bar2", "foo3": "bar3"} m2 := map[string]string{"foo": "bar", "foo2": "bar2"} b := maps.Equal(m, m1) fmt.Println(b) // false b = maps.Equal(m, m2) fmt.Println(b) // true }
maps.EqualFunc
定義如下:
func EqualFunc[M1 ~map[K]V1, M2 ~map[K]V2, K comparable, V1, V2 any](m1 M1, m2 M2, eq func(V1, V2) bool) bool
類似于Equal函數(shù),但使用自定義的 eq 函數(shù)進行比較。
package main import ( "fmt" "maps" "strings" ) func main() { m1 := map[int]string{ 1: "one", 10: "Ten", 1000: "THOUSAND", } m2 := map[int][]byte{ 1: []byte("One"), 10: []byte("Ten"), 1000: []byte("Thousand"), } eq := maps.EqualFunc(m1, m2, func(v1 string, v2 []byte) bool { return strings.ToLower(v1) == strings.ToLower(string(v2)) }) fmt.Println(eq) // true }
將值轉(zhuǎn)換為小寫的字符串后進行比較。
到此這篇關(guān)于Go1.21新增maps包的用法詳解的文章就介紹到這了,更多相關(guān)Go1.21 maps包內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于golang高并發(fā)的實現(xiàn)與注意事項說明
這篇文章主要介紹了關(guān)于golang高并發(fā)的實現(xiàn)與注意事項說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-05-05數(shù)據(jù)競爭和內(nèi)存重分配Golang slice并發(fā)不安全問題解決
這篇文章主要為大家介紹了數(shù)據(jù)競爭和內(nèi)存重分配Golang slice并發(fā)不安全問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10