golang捕獲ctrl+c退出程式

來源:互聯網
上載者:User
這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。

在golang當中如何捕獲ctrl+c命令,讓程式有序的的退出?

首先測試一段golang代碼,捕獲SIGINT和SIGKILL

c := make(chan os.Signal, 1)signal.Notify(c, os.Interrupt, os.Kill)s := <-cfmt.Println("Got signal:", s)

在多goroutines當中如何退出?我們假設有一個生產者,一個消費者,這個時候應該讓生產者去捕獲訊息,關閉channel,生產者退出;消費者感知到channel關閉,消費者退出。

package mainimport (    "time"    "fmt"    "os"    "os/signal"    "sync")var c chan os.Signalvar msgQueue chan *stringvar wg sync.WaitGroupfunc Producer(){    i := 0    LOOP:    for{        select {        case s := <-c:            fmt.Println()            fmt.Println("Producer | get", s)            break LOOP        default:        }        i ++        s := fmt.Sprintf("work-%d", i)        fmt.Println("Producer | produce", s)        msgQueue <- &s        time.Sleep(500 * time.Millisecond)    }    close(msgQueue)    fmt.Println("Producer | close channel, exit")    wg.Done()}func Consumer(){    for m := range msgQueue{        if m != nil{            fmt.Println("Consumer | consume", *m)        }else{            fmt.Println("Consumer | channel closed")            break        }    }    fmt.Println("Consumer | exit")    wg.Done()}func main(){    c = make(chan os.Signal, 1)    msgQueue = make(chan *string, 1000)    signal.Notify(c, os.Interrupt, os.Kill)    //pruducer    wg.Add(1)    go Producer()    //consumer    wg.Add(1)    go Consumer()    wg.Wait()}

運行結果:

Producer | produce work-1Consumer | consume work-1Producer | produce work-2Consumer | consume work-2Producer | produce work-3Consumer | consume work-3Producer | produce work-4Consumer | consume work-4Producer | get interruptProducer | close channel, exitConsumer | exit

參考:
1. http://www.oschina.net/translate/golang-graceful-stop?lang=eng

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.