1. 程式人生 > >Go語言流程控制

Go語言流程控制

1.條件語句

幾個注意點和C#不一樣的。

if a < 5 {
       return 0
} else {
       return 1
}

① 條件語句不需要使用括號將條件包含起來 a<5 ,C#必須有()

②無論語句體內有幾條語句,花括號{}都是必須存在的;C#如果只有一條語句可以省略{}

③左花括號{必須與if或者else處於同一行 C#的{}是換行的

④在有返回值的函式中,不允許將“最終的”return語句包含在if...else...結構中,

否則會編譯失敗(這句話錯誤的 1.1版Go語言和之後的新版已經支援if else條件語句直接return返回值。),所以上面的demo是可以編譯通過的。

2.選擇語句

①條件表示式不限制為常量或者整數

②單個case中,可以出現多個結果選項

③Go語言不需要用break來明確退出一個case;C#需要在每一個case結束之後加上break

④增加了fallthrough方法 主要用於多個相同case合併,Go就相當於預設加了break;

和C#正好相反

switch i {
case 0:
   fmt.Printf("0")
case 1:
   fmt.Printf("1")
case 2:
   fallthrough
case 3:
   fmt.Printf("3")
case 4, 5, 6:
   fmt.Printf(
"4, 5, 6") default: fmt.Printf("Default") }

如上例子,case 2中有語句fallthrough,那麼當i=2時候,執行完fallthrough會執行case3,由此打印出了“3”

⑤可以不設定switch之後的條件表示式,在此種情況下,整個switch結構與多個 if...else... 的邏輯作用等同。如下程式碼

switch {
case 0 <= Num && Num <= 3:
   fmt.Printf("0-3")
case 4 <= Num && Num <= 6
: fmt.Printf("4-6") case 7 <= Num && Num <= 9: fmt.Printf("7-9") }

3.迴圈語句

Go語言中的迴圈語句只支援for關鍵字,而不支援while和do-while結構。

①for後面的條件表示式不需要用圓括號()包含起來

模擬while語句:直接用for後面不加條件

sum := 0
for {
    sum++
    if sum > 100 {
       break
    }
}

②for迴圈中條件表示式中也支援多重賦值

a := []int{1, 2, 3, 4, 5, 6}
for i, j := 0, len(a) – 1; i < j; i, j = i + 1, j – 1 {
      a[i], a[j] = a[j], a[i]
}

如上程式碼:

a) 初始值 i=0 ,j= len(a) – 1

b)迴圈的條件是 i < j

c)每執行一次 i+1 ,j-1

迴圈體: a[i], a[j] = a[j], a[i]

Go語言中的for迴圈與C語言一樣,都允許在迴圈條件中定義和初始化變數,唯一的區別是,Go語言不支援以逗號為間隔的多個賦值語句,必須使用平行賦值的方式來初始化多個變數。

③Go語言的for迴圈同樣支援continue和break來控制迴圈,但是它提供了一個更高階的 break,可以選擇中斷哪一個迴圈, 如下程式碼:

break語句終止的是JLoop標籤處的外層迴圈

for j := 0; j < 5; j++ {
    for i := 0; i < 10; i++ {
        if i > 5 {
             break JLoop
         }
     fmt.Println(i)
  }
}
JLoop: //Do Something 

如果是C#,只能跳出第一層迴圈,而不能直接跳出第二層迴圈,這也是區別的地方之一

4.跳轉語句

Go語言支援goto語句

func myfunc() {
  i := 0
  HERE:
   fmt.Println(i)
  i++
  if i < 10 {
    goto HERE
  }
}

for…range 是什麼,就相當於原來的foreach中迭代 k,v結構。

for index, value := range mySlice {
  fmt.Println("index: " + index)
  fmt.Println("value: " + value)
}

下面這個文章詳細描述了range的問題,裡面會有坑

http://www.jb51.net/article/92401.htm

當迭代切片時,關鍵字range 會返回兩個值。第一個值是當前迭代到的索引位置,第二個

值是該位置對應元素值的一份副本

這張圖比較好的說明了range的返回值,重點在於值是副本