欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Go1.21新增slices包中函數(shù)的用法詳解

 更新時間:2023年08月21日 09:05:22   作者:路多辛  
Go?1.21新增的?slices?包提供了很多和切片相關的函數(shù),可以用于任何類型的切片,本文為大家整理了部分函數(shù)的具體用法,感興趣的小伙伴可以了解一下

slices.Delete

定義如下:

func Delete[S ~[]E, E any](s S, i, j int) S

從 s 中刪除元素 s[i:j],返回修改后的切片。如果 s[i:j] 不是 s 的有效切片,則會 panic。Delete是 O(len(s)-j),因此如果必須刪除許多項,最好調(diào)用一次刪除全部,而不是逐個刪除。Delete不能修改元素 s[len(s)-(j-i):len(s)]。如果這些元素包含指針,可以考慮將這些元素歸零,以便它們引用的對象可以被垃圾回收。簡單示例如下:

package main
import (
    "fmt"
    "slices"
)
func main() {
    letters := []string{"a", "b", "c", "d", "e"}
    letters = slices.Delete(letters, 1, 4)
    fmt.Println(letters) // [a e]
}

slices.DeleteFunc

定義如下:

func DeleteFunc[S ~[]E, E any](s S, del func(E) bool) S

從 s 中刪除 del函數(shù)返回 true 的元素,并返回修改后的切片。當 DeleteFunc 刪除m個元素時,它可能不會修改元素s[len(s)-m:len(s)]。如果這些元素包含指針,、可以考慮將這些元素歸零,以便它們引用的對象可以被垃圾回收。簡單示例如下:

package main
import (
    "fmt"
    "slices"
)
func main() {
    seq := []int{0, 1, 1, 2, 3, 5, 8}
    seq = slices.DeleteFunc(seq, func(n int) bool {
        return n%2 != 0 // 刪除奇數(shù)
    })
    fmt.Println(seq) // [0 2 8]
}

slices.Equal

定義如下:

func Equal[S ~[]E, E comparable](s1, s2 S) bool

判斷兩個切片是否相等(長度相同且所有元素相等)。如果長度不同,返回 false。如果長度相同,將按索引遞增的順序比較元素,并在第一個不相等出現(xiàn)時停止比較。簡單示例如下:

package main
import (
    "fmt"
    "slices"
)
func main() {
    numbers := []int{0, 42, 8}
    fmt.Println(slices.Equal(numbers, []int{0, 42, 8})) // true
    fmt.Println(slices.Equal(numbers, []int{10})) // false
}

slices.EqualFunc

定義如下:

func EqualFunc[S1 ~[]E1, S2 ~[]E2, E1, E2 any](s1 S1, s2 S2, eq func(E1, E2) bool) bool

對每對元素使用自定義函數(shù)來判斷兩個片是否相等。如果長度不同,返回false。如果長度相同,將按索引遞增的順序比較元素,并在 eq 返回 false 的第一個索引處停止比較。簡單示例如下:

package main
import (
    "fmt"
    "slices"
    "strconv"
)
func main() {
    numbers := []int{0, 42, 8}
    strings := []string{"000", "42", "0o10"}
    equal := slices.EqualFunc(numbers, strings, func(n int, s string) bool {
        sn, err := strconv.ParseInt(s, 0, 64)
        if err != nil {
            return false
        }
        return n == int(sn)
    })
    fmt.Println(equal) // true
}

slices.Grow

定義如下:

func Grow[S ~[]E, E any](s S, n int) S

增加片的容量,以為另外 n 個元素提供空間。在Grow(n)之后,至少可以將n個元素添加到片中,而無需再進行分配。如果 n 為負值或太大而無法分配內(nèi)存,就會 panic。

slices.Index

定義如下:

func Index[S ~[]E, E comparable](s S, v E) int

返回 v 在 s 中第一次出現(xiàn)的索引,如果不存在則返回-1。簡單示例如下:

package main
import (
    "fmt"
    "slices"
)
func main() {
    numbers := []int{0, 42, 8}
    fmt.Println(slices.Index(numbers, 8)) // 2
    fmt.Println(slices.Index(numbers, 7)) // -1
}

slices.IndexFunc

定義如下:

func IndexFunc[S ~[]E, E any](s S, f func(E) bool) int

返回第一個滿足 f(s[i]) 的索引 i,如果不滿足則返回-1。簡單示例如下:

package main
import (
    "fmt"
    "slices"
)
func main() {
    numbers := []int{0, 42, -10, 8}
    i := slices.IndexFunc(numbers, func(n int) bool {
        return n < 0
    })
    fmt.Println("First negative at index", i) // 2
}

slices.Insert

定義如下:

func Insert[S ~[]E, E any](s S, i int, v ...E) S

將 值 v… 在索引 i 處插入到 s,返回修改后的切片。s[i:] 中的元素被上移以騰出空間。在返回的切片 r 中,r[i] == v[0], r[i+len(v)] == 原來在 r[i] 處的 value。如果超出范圍,則 panic。這個函數(shù)的復雜度為 O(len(s) + len(v))。簡單示例如下:

package main
import (
    "fmt"
    "slices"
)
func main() {
    names := []string{"Alice", "Bob", "Vera"}
    names = slices.Insert(names, 1, "Bill", "Billie")
    names = slices.Insert(names, len(names), "Zac")
    fmt.Println(names) // [Alice Bill Billie Bob Vera Zac]
}

slices.IsSorted

定義如下:

func IsSorted[S ~[]E, E cmp.Ordered](x S) bool

判斷 x 是否按升序排序。簡單示例如下:

package main
import (
    "fmt"
    "slices"
)
func main() {
    fmt.Println(slices.IsSorted([]string{"Alice", "Bob", "Vera"})) // true
    fmt.Println(slices.IsSorted([]int{0, 2, 1})) // false
}

【參考資料】

Package slices(https://golang.google.cn/pkg/slices/

到此這篇關于Go1.21新增slices包中函數(shù)的用法詳解的文章就介紹到這了,更多相關Go1.21 slices包內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Go結合Redis用最簡單的方式實現(xiàn)分布式鎖

    Go結合Redis用最簡單的方式實現(xiàn)分布式鎖

    本文主要介紹了Go結合Redis用最簡單的方式實現(xiàn)分布式鎖示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • golang規(guī)則引擎gengine用法案例

    golang規(guī)則引擎gengine用法案例

    這篇文章主要為大家介紹了golang?規(guī)則引擎gengine用法案例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2024-01-01
  • 用Go+WebSocket快速實現(xiàn)一個chat服務

    用Go+WebSocket快速實現(xiàn)一個chat服務

    這篇文章主要介紹了用Go+WebSocket快速實現(xiàn)一個chat服務,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • Go方法簡單性和高效性的充分體現(xiàn)詳解

    Go方法簡單性和高效性的充分體現(xiàn)詳解

    本文深入探討了Go語言中方法的各個方面,包括基礎概念、定義與聲明、特性、實戰(zhàn)應用以及性能考量,文章充滿技術深度,通過實例和代碼演示,力圖幫助讀者全面理解Go方法的設計哲學和最佳實踐
    2023-10-10
  • Go語言Zap庫Logger的定制化和封裝使用詳解

    Go語言Zap庫Logger的定制化和封裝使用詳解

    這篇文章主要介紹了Go語言Zap庫Logger的定制化和封裝使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • 基于Go語言實現(xiàn)簡單網(wǎng)絡聊天室(命令行模式)

    基于Go語言實現(xiàn)簡單網(wǎng)絡聊天室(命令行模式)

    這篇文章主要為大家詳細介紹了如何基于Go語言實現(xiàn)簡單網(wǎng)絡聊天室,文中的示例代碼簡潔易懂,有需要的小伙伴可以跟隨小編一起學習一下
    2025-02-02
  • Go 并發(fā)控制context實現(xiàn)原理剖析(小結)

    Go 并發(fā)控制context實現(xiàn)原理剖析(小結)

    Golang context是Golang應用開發(fā)常用的并發(fā)控制技術,這篇文章主要介紹了Go 并發(fā)控制context實現(xiàn)原理剖析(小結),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • Go語言數(shù)據(jù)類型詳細介紹

    Go語言數(shù)據(jù)類型詳細介紹

    這篇文章主要介紹了Go語言數(shù)據(jù)類型詳細介紹,Go語言數(shù)據(jù)類型包含基礎類型和復合類型兩大類,下文關于這兩類型的相關介紹,需要的小伙伴可以參考一下
    2022-03-03
  • Go語言中如何通過方法為類型添加行為

    Go語言中如何通過方法為類型添加行為

    這篇文章主要介紹了Go語言中如何通過方法為類型添加行為的相關資料,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • Golang中使用errors返回調(diào)用堆棧信息

    Golang中使用errors返回調(diào)用堆棧信息

    這篇文章給大家介紹了Golang中如何使用errors返回調(diào)用堆棧信息,文章通過代碼示例給大家介紹的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下
    2023-12-12

最新評論