Go by Example: [27] Select
Select
Go
언어에는 채널이라는 고루틴간의 통신수단이 제공됩니다. select
문은 이러한 채널에서
어떤채널에 어떠한 메세지가 오면 처리할 수 있는 채널전용 분기문(switch
)입니다.
고루틴 + 채널
조합에 select
가 합쳐져서 Go
언어를 더욱 강력하게 만들어주게 됩니다.
package main
import "time"
import "fmt"
func main() {
c1 := make(chan string) // [1]
c2 := make(chan string)
go func() { // [2]
time.Sleep(time.Second * 1)
c1 <- "one"
}()
go func() {
time.Sleep(time.Second * 2)
c2 <- "two"
}()
for i := 0; i < 2; i++ { // [3]
select {
case msg1 := <-c1:
fmt.Println("received", msg1)
case msg2 := <-c2:
fmt.Println("received", msg2)
}
}
}
- 2개의 문자열 전송 채널을 생성한 후
select
로 각 채널을 구별해서 처리합니다. - 각 채널은 특정시간 후에 가각 채널에 메세지를 전송하고 있습니다.
동시실행 고루틴
은 RPC Blocking을 구현해주는 것입니다. select
문을 이용해서 각각의 채널을 구별해서 해당 처리를 하고 있습니다.
실행하면 다음과 같습니다.
$ time go run select.go
received one
received two
real 0m2.245s
one
메세지를 받은 후, two
메세지를 받게 되었습니다.
전체 실행시간은 2초 정도였습니다. time.Sleep()
함수를 사용해서 1,2초간 대기했기 때문입니다.