這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
if語句
i f x > 0 { // {是強制的,且必須和if在同一行 return y} else { return x}
if 和 switch 接受初始化語句,通常用於設定一個(局部)變數。
if err := Chmod(0664); err != nil { //nil 與 C 的 NULL 類似fmt.Printf(err) //err 的範圍被限定在 if 內return err}
goto語句
用 goto 跳轉到一定是當前函數內定義的標籤
func myfunc() { i := 0 Here: // 這行的第一個詞,以分號結束作為標籤,標籤名區分大小寫 println(i) i++ goto Here // 跳轉}
for語句
Go 的 for 迴圈有三種形式,只有其中的一種使用分號。
for init; condition; post { } // 和C的for一樣for condition {} // 和while一樣for {} // 死迴圈1、sum := 0for i:=0; i<10; i++ {sum+=i ←sum = sum + i 的簡化寫法 } 2、for i,j:=0, len(a)-1; i<j; i,j=i+1,j-1 {a[i], a[j] = a[j], a[i] //平行賦值 }
break和continue
利用 break 可以提前退出迴圈,break 終止當前的迴圈。
for i:=0; i<10; i++ { if i>5{ break //終止這個迴圈,只列印 0 到 5 } println(i)}
迴圈嵌套迴圈時,可以在 break 後指定標籤。用標籤決定哪個迴圈被終止:
J: for j:=0; j<5; j++ { for i:=0; i<10; i++ { if i>5{ break J // 現在種植的是j迴圈,而不是i的那個 } println(i) } }
利用 continue 讓迴圈進入下一個迭代,而略過剩下的所有代碼。下面迴圈列印了 0 到 5。
for i:=0; i<10; i++ { if i>5{ continue // 跳過迴圈中所有的代碼println(i) } println(i)}
range
range可用於迴圈,支援slice、array、string、map和channel,range 是個迭代器,當被調用的時候,從它迴圈的內容中返回一個索引值對。基於 不同的內容,range 返回不同的東西。
// 遍曆arraylist := []string {"a", "b", "c", "d", "e", "f"} for k, v := range list { // k,v索引值對:k為key,v為value}// 遍曆字串for pos, char := range "aΦx" {fmt.Printf("character '%c' starts at byte position %d\n",char, pos)}
switch語句
Go 的 switch 非常靈活。運算式不必是常量或整數,執行的過程從上至下,直到找到匹 配項,而如果 switch 沒有運算式,它會匹配 true 。這產生一種可能——使用 switch 編寫 if-else-if-else 判斷序列。
func unhex(c byte) byte { switch { case '0'<=c&&c<='9': return c - '0' case 'a'<=c&&c<='f': return c - 'a' + 10 case 'A'<=c&&c<='F': return c - 'A' + 10 } return 0 }
它不會匹配失敗後自動向下嘗試,但是可以使用 fallthrough 使其這樣做。沒 有 fallthrough:
switch i { case 0: // 空的case體case 1: f() // 當i==0時,f不會被調用!}
而這樣:
switch i { case 0: fallthrough case 1: f() // 當i==0時,f會被調用! }
用 default 可以指定當其他所有分支都不匹配的時候的行為。
switch i { case 0: case 1: f() default: g() //當i不等於0或1時調用}
分支可以使用逗號分隔的列表。
func shouldEscape(c byte) bool { switch c { case ' ', '?', '&', '=', '#', '+': // ,或者 “or”都可以 return true } return false}
使用 switch 對位元組數組進行比較的例子:
func Compare(a, b []byte) int { for i:=0; i< len(a)&&i< len(b); i++ { switch { case a[i] > b[i]: return 1 case a[i] < b[i]: return -1 } } switch { 1 case len(a) < len(b): return -1 case len(a) > len(b): return 1 } return 0}