中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Golang斷言與閉包如何使用

發布時間:2022-08-01 09:29:01 來源:億速云 閱讀:144 作者:iii 欄目:開發技術

這篇“Golang斷言與閉包如何使用”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Golang斷言與閉包如何使用”文章吧。

1. Go斷言的使用

Go中的斷言用于判斷變量的類型,其使用形式如下所示:

value, ok := x.(T)

上面的代碼是判斷x是否為T類型的變量:

  • 如果 T 的某個具體的類型,斷言會檢查 x 是否為該類型,如果是的話買就返回 x 以及一個布爾值true,反之返回一個false

  • 如果 T 是接口類型,類型斷言會檢查 x 的動態類型是否滿足 T。如果檢查成功,返回值是一個類型為 T 的接口值,以及一個布爾值true,反之返回一個false

  • 我們也可以不接受返回的布爾值,在這種情況下,如果斷言失敗,會直接panic,所以非常不推薦這種處理方式

另外,斷言和可以與switch配合使用

    switch a.(type) {
        case int:
        fmt.Println("the type of a is int")
        case string:
        fmt.Println("the type of a is string")
        case float64:
        fmt.Println("the type of a is float")
        default:
        fmt.Println("unknown type")
    }

2. 閉包的解讀

閉包是由函數和與其相關的引用環境組合而成的實體。

概念上說起來有些抽象,下面我們以一個具體的例子來理解。

func foo1(x int) func() {
  return func() {
    x = x + 1
    fmt.Printf("foo2 val = %d\n", x)
  }
}

f1 := foo1(1)
f1() // 2
f1() // 3

在上面的例子中,f1() 與他的變量x(值為1)共同組成了一個閉包,每次調用f1(),x的值就會+1并且打印。

從某種意義上來說,閉包延長了變量的生命周期(棧上分配改為了堆上分配)。

2.1 指針傳遞

func foo2(x *int) func() {
  return func() {
    *x = *x + 1
    fmt.Printf("foo2 val = %d\n", *x)
  }
}

x := 1
f1 := foo2(&x)
f2 := foo2(&x)
f1() // 2
f2() // 3

通過第一個例子,我們知道,函數以及其環境(傳入的變量)組成了閉包,這個時候,如果傳入的是一個指針,那么就會存在多個閉包共用一個變量的情況。

2.2 延遲綁定

閉包的延遲綁定,通俗地說,就是閉包的函數在第一次調用的時候才會與環境的變量進行綁定,我們依然以上面提到的兩個函數為例子:

func foo1(x int) func() {
  return func() {
    x = x + 1
    fmt.Printf("foo2 val = %d\n", x)
  }
}

func foo2(x *int) func() {
  return func() {
    *x = *x + 1
    fmt.Printf("foo2 val = %d\n", *x)
  }
}

x := 1
f1 := foo1(x)
f2 := foo2(&x)
f2() // 2
f1() // 3
  • 我們創建了f1與f2兩個閉包函數,以及變量 x 的值為1

  • 在f1與f2創建的時候,變量并沒有與函數綁定

  • 第一次調用f2()時,&x與其綁定,x的值+1,變為2

  • 第一次調用f1()時,x與其綁定,這時x已經變為2了,再+1,所以變為3

2.3 Go Routine的延遲綁定

我們在一個函數中啟動 Go Routine 調用另一個函數:

func show(v interface{}) {
    fmt.Printf("foo4 val = %v\n", v)
}
func foo4() {
    values := []int{1, 2, 3, 5}
    for _, val := range values {
        go show(val)
    }
}

foo4()
//foo3 val = 2
//foo3 val = 3
//foo3 val = 1
//foo3 val = 5

因為Go Routine的執行順序是隨機并行的,因此執行多次foo4()輸出的順序不一行相同,但是一定打印了“1,2,3,5”各個元素。

但是,如果我們以匿名函數的形式嘗試復現上面的邏輯,會發現:

func foo5() {
    values := []int{1, 2, 3, 5}
    for _, val := range values {
        go func() {
            fmt.Printf("foo5 val = %v\n", val)
        }()
    }
}

foo5()
//foo3 val = 5
//foo3 val = 5
//foo3 val = 5
//foo3 val = 5

其實這個問題的本質同閉包的延遲綁定,或者說,這段匿名函數的對象就是閉包。在我們調用go func() { xxx }()的時候,只要沒有真正開始執行這段代碼,那它還只是一段函數聲明。而在這段匿名函數被執行的時候,才是內部變量尋找真正賦值的時候。for-loop的遍歷幾乎是“瞬時”完成的,4個Go Routine真正被執行在其后,所以會產生上面的情況。

以上就是關于“Golang斷言與閉包如何使用”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

罗山县| 宁城县| 南平市| 凉山| 英吉沙县| 南溪县| 五指山市| 南木林县| 内江市| 闽侯县| 砚山县| 海阳市| 渭源县| 濮阳市| 油尖旺区| 淮北市| 阿拉尔市| 辉县市| 大新县| 平罗县| 抚顺县| 肇东市| 灵宝市| 潮安县| 渝中区| 宁晋县| 峡江县| 厦门市| 页游| 泸定县| 钟山县| 上林县| 内乡县| 阿城市| 江都市| 精河县| 南雄市| 海南省| 大安市| 榆社县| 靖州|