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 := 0
for 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 返回不同的東西。
// 遍歷array
list := []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
}