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)
        }
    }
}
  1. 2개의 문자열 전송 채널을 생성한 후 select로 각 채널을 구별해서 처리합니다.
  2. 각 채널은 특정시간 후에 가각 채널에 메세지를 전송하고 있습니다.
    동시실행 고루틴은 RPC Blocking을 구현해주는 것입니다.
  3. select 문을 이용해서 각각의 채널을 구별해서 해당 처리를 하고 있습니다.

실행하면 다음과 같습니다.

$ time go run select.go 
received one
received two

real  0m2.245s

one 메세지를 받은 후, two메세지를 받게 되었습니다.
전체 실행시간은 2초 정도였습니다. time.Sleep()함수를 사용해서 1,2초간 대기했기 때문입니다.