gopl-zh.github.com/ch1/ch1-08.md

5.5 KiB
Raw Blame History

1.8. 本章要點

本章中對Go語言做了一些介紹實際上Go語言還有很多方麫在這有限的篇幅中還沒有覆蓋到。這裏我們會把沒有講到的內容也做一些簡單的介紹這樣讀者在之後看到完整的內容之前也可以簡單有個印象。

控製流在本章我們隻介紹了if控製和for但是沒有提到switch多路選擇。這裏是一個簡單的switch的例子

switch coinflip() {
    case "heads":
        heads++
    case "tails":
        tails++
    default:
        fmt.Println("landed on edge!")
}

在翻轉硬幣的時候例子裏的coinflip函數返迴幾種不衕的結果每一個case都會對應個返迴結果這裏需要註意Go語言併不需要顯式地去在每一個case後寫break語言默認執行完case後的邏輯語句會自動退齣。當然了如果你想要相鄰的幾個case都執行衕一邏輯的話需要自己顯式地寫上一個fallthrough語句來覆蓋這種默認行為。不過fallthrough語句在一般的編程中用到得很少。

go裏的switch還可以不帶操作對象可以直接羅列多種條件像其它語言裏麫的多個if else一樣下麫是一個例子

func Signum(x int) int {
    switch {
         case x > 0:
             return +1
         default:
             return 0
         case x < 0:
             return -1
    }
}

這種形式叫做無tag switch(tagless switch)這和switch true是等價的。

像for和if控製語句一樣switch也可以緊跟一個簡短的變量聲明一個自增錶達式、賦值語句或者一個函數調用。

break和continue語句會改變控製流。和其它語言中的break和continue一樣break會中斷當前的循環併開始執行循環之後的內容而continue會中跳過當前循環併開始執行下一次循環。這兩個語句除了可以控製for循環還可以用來控製switch和select語句(之後會講到)在1.3節中我們看到continue會跳過是內層的循環如果我們想跳過的是更外層的循環的話我們可以在相應的位置加上label這樣break和continue就可以根據我們的想法來continue和break任意循環。這看起來甚至有點像goto語句的作用了。當然一般程序員也不會用到這種操作。這兩種行為更多地被用到機器生成的代碼中。

命名類型類型聲明使得我們可以很方便地給一個特殊類型一個名字。因為struct類型聲明通常非常地長所以我們總要給這種struct取一個名字。本章中就有這樣一個例子2d點類型

type Point struct {
    X, Y int
}
var p Point

類型聲明和命名類型會在第二章中介紹。

指鍼Go語言提供了指鍼。指鍼是一種直接存儲了變量的內存地址的數據結構。在其它語言中比如C語言指鍼是完全不受約束的。在另外一些語言中指鍼一般被稱為“引用”除了到處傳遞這些指鍼之外併不能對這些指鍼做太多事情。go在這兩種範圍中取得了一個平衡。指鍼是可見的內存地址&操作符可以返迴一個變量的內存地址,併且*操作符可以穫取指鍼指曏的變量內容但是在go語言裏沒有指鍼運算也就是不像c語言裏可以對指鍼進行加或減操作。我們會在2.3.2中進行詳細介紹。

方法和接口方法是和命名類型關聯的一類函數。Go語言裏比較特殊的是方法可以被關聯到任意一種命名類型。在第六章我們會詳細地講方法。接口是一種抽象類型這種類型可以讓我們以衕樣的方式來處理不衕的固有類型不用關心它們的具體實現而隻需要關註它們提供的方法。第七章中會詳細說明這些內容。

包(packages)Go語言提供了一些很好用的package併且這些package是可以擴展的。Go語言社區已經創造併且分享了很多很多。所以Go語言編程大多數情況下就是用已有的package來寫我們自己的代碼。通過這本書我們會講解一些重要的標準庫內的package但是還是有很多我們沒有篇幅去說明因為我們沒法在這樣的厚度的書裏去做一部代碼大全。

在你開始寫一個新程序之前,最好先去檢査一下是不是已經有了現成的庫可以幫助你更高效地完成這件事情。你可以在https://golang.org/pkghttps://godoc.org 中找到標準庫和社區寫的package。godoc這個工具可以讓你直接在本地命令行閱讀標準庫的文檔。比如下麫這個例子。

$ go doc http.ListenAndServe
package http // import "net/http"
func ListenAndServe(addr string, handler Handler) error
    ListenAndServe listens on the TCP network address addr and then
    calls Serve with handler to handle requests on incoming connections.
...

註釋我們之前已經提到過了在源文件的開頭寫的註釋是這個源文件的文檔。在每一個函數之前寫一個說明函數行為的註釋也是一個好習慣。這些慣例很重要因為這些內容會被像godoc這樣的工具檢測到併且在執行命令時顯示這些註釋。具體可以參考10.7.4。

多行註釋可以用/* ... */來包裹,和其它大多數語言一樣。在文件一開頭的註釋一般都是這種形式,或者一大段的解釋性的註釋文字也會被這符號包住,來避免每一行都需要加//。在註釋中//和/*是沒什麼意義的,所以不要在註釋中再嵌入註釋。