1. 程式人生 > >GO語言method、interface、reflection、select

GO語言method、interface、reflection、select

語言 go method

方法method

-GO方法雖沒有class,依舊有method

-通過顯示說明receiver來實現與某個類型的組合

-只能為同一個包中的類型定義方法

-RECEIVER可以是類型的值或指針

-不存在方法重載

-可以使用值或指針來調用方法,編譯器會自動完成轉換

-從某種意義上來說,方法是函數的語法糖,因為receiver其實就是方法所接收的第一個參數

-如果外部結構和嵌入結構存在同名方法,則優先調用外部結構的方法

-類型別名不會擁有底層類型所附帶的方法

-方法可以調用結構中的非公開字段

接口interface

-接口是一個或多個方法簽名的集合


反射reflection



並發concurrency

Channel

-Channel是goroutine溝通的橋梁,大都是阻塞同步的

-通過make創建,close關閉

-Channel是引用類型

package main

import "fmt"

import "time"

func main(){

c :=make(chan bool)

go func(){

fmt.Println("GO GO GO")

c <-true

}()

<-c

time.Sleep(2*time.Second)


}


-可以使用for range 來叠代不斷操作channel

package main

import "fmt"

//import "time"

func main(){

c :=make(chan bool)

go func(){

fmt.Println("GO GO GO")

c <-true

close(c)

}()

for v :=range c{

fmt.Println(v)

}


}


-可以設置單項或雙向通道

-可以設置緩存大小,在未被填滿前不會發生阻塞

package main

import "fmt"

import "runtime"

func main(){

runtime.GOMAXPROCS(runtime.NumCPU())

c :=make(chan bool,10)

for i :=0;i<10;i++{

go Go(c,i)

}

for i :=0;i<10;i++{

<-c

}

}

func Go(c chan bool,index int){

a :=1

for i :=0;i<100000000;i++{

a+=1

}

fmt.Println(index,a)

c<-true


}

等價///

package main

import "fmt"

import "runtime"

import "sync"

func main(){

runtime.GOMAXPROCS(runtime.NumCPU())

wg :=sync.WaitGroup{}

wg.Add(10)

for i :=0;i<10;i++{

go Go(&wg,i)

}

wg.Wait()

}

func Go(wg *sync.WaitGroup,index int){

a :=1

for i :=0;i<100000000;i++{

a+=1

}

fmt.Println(index,a)

wg.Done()


}


Select

-可處理一個或多個channel的發送與接收

-同時有多個可用的channel時按隨機順序處理

-可用空的select來阻塞main函數

-可設置超時


本文出自 “DBAspace” 博客,請務必保留此出處http://dbaspace.blog.51cto.com/6873717/1963461

GO語言method、interface、reflection、select