這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
關鍵字
break default func interface selectcase defer go map structchan else goto package switchconst fallthrough if range typecontinue for import return var
內建常量:
true false iota nil
內建類型:
int int8 int16 int32 int64uint uint8 uint16 uint32 uint64 uintptrfloat32 float64 complex128 complex64bool byte rune string error
內建函數:
make len cap new append copy close deletecomplex real imagpanic recover
聲明
var i = 1000func main() {}const PI = 3.141592653589793 type Model struct {}
變數
var 名字 類型 = 運算式
指標
取地址 p := &x解引用 *p = 2
一些資料類型
array
// 字面量array := [5]int{1,2,3,4,5}
slice
var myArray [10]int = [10]int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}// 基於數組var mySlice1 []int = myArray[:5]// 使用makemySlice2 := make([]int, 5, 10)// 字面量mySlice3 := []int{1, 2, 3, 4, 5}i, v := range []mySlice1
map
var myMap map[keyType]valueTypemake(map[keyType]valueType, 100)myMap = map[keyType]valueTyep {}
new
new(類型) 返回該類型的一個指標p := new(int)```go# 生命週期包級的變數和程式的生命週期一致局部變數不再被引用時自動銷毀 # 流程式控制制## if else```gofunc example(x int) int { if x == 0 { return 5 } else { return x }}
switch case default fallthrough
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")}
for break continue
普通for迴圈
sum := 0for i := 0; i < 10; i++ { sum += i } 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]}
模仿while(go沒有while、do-while)
sum := 0 for { sum++ if sum > 100 { break } }
break跳轉
for j := 0; j < 5; j++ { for i := 0; i < 10; i++ { if i > 5 { break JLoop } fmt.Println(i) } }JLoop: // ...
goto
介面
interface Reader {
read()
}
函數
defer func1()
defer func2()
先進後出,所以先執行func2,後執行func1
goroutine
啟動一個goroutine(go的並發體)
go f()
建立一個channel(go的通訊機制)
ch = make(chan int)ch = make(chan int, 3) // 帶緩衝
接收
x = <-ch // 從ch接收資料,並儲存在x
發送
ch <- x // 將x的內容發送到ch
關閉
close(ch)
多工
select { case <-ch1: // case x := <-ch2: // fmt.Println(x) case ch3 <- y: // default: //}