码迷,mamicode.com
首页 > 其他好文 > 详细

4.11 timeout

时间:2018-03-22 01:48:36      阅读:183      评论:0      收藏:0      [点我收藏+]

标签:string   ase   end   ret   lis   man   tin   pac   UNC   


package main

import (
    "fmt"
    "time"
)

func main() {

    to := time.After(3 * time.Second)
    list := make([]string, 0)
    done := make(chan bool, 1)

    fmt.Println("Starting to insert items")
    go func() {
        defer fmt.Println("Exiting goroutine")
        for {
            select {
            case <-to:
                fmt.Println("The time is up")
                done <- true
                return
            default:
                list = append(list, time.Now().String())
            }
        }
    }()

    <-done
    fmt.Printf("Managed to insert %d items\n", len(list))

}

/*

Starting to insert items
The time is up
Exiting goroutine
Managed to insert 1866573 items

*/

4.11 timeout

标签:string   ase   end   ret   lis   man   tin   pac   UNC   

原文地址:https://www.cnblogs.com/zrdpy/p/8620891.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!