分享
  1. 首页
  2. 文章

golang context.WithTimeout 超时处理

ylqmf · · 10082 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

<span style="font-size:18px;color:#3333ff;">package main
import (
 "golang.org/x/net/context"
 "log"
 "math/rand"
 "time"
)
func test(is_first *bool, prev_map *map[string]string) {
 rand.Seed(int64(time.Now().Nanosecond()))
 ch := make(chan bool)
 ctx, _ := context.WithTimeout(context.Background(), 50*time.Millisecond)
 go func() {
 if *is_first {
 (*prev_map)["a"] = "1"
 } else {
 (*prev_map)["a"] = "2"
 }
 time.Sleep(time.Duration(rand.Intn(100)) * time.Millisecond)
 ch <- true
 }()
 select {
 case <-ch:
 *is_first = false
 (*prev_map)["b"] = "fast"
 return
 case <-ctx.Done():
 *is_first = true
 (*prev_map)["b"] = "slow"
 return
 }
}
func main() {
 is_first := true
 prev_map := make(map[string]string)
 for {
 test(&is_first, &prev_map)
 time.Sleep(time.Second)
 log.Println(prev_map, is_first)
 }
}</span>



<span style="font-size:18px;color:#3333ff;">[work@localhost test]$ go run main.go 
2016年08月18日 23:22:26 map[a:1 b:fast] false
2016年08月18日 23:22:27 map[a:2 b:slow] true
2016年08月18日 23:22:28 map[a:1 b:slow] true
2016年08月18日 23:22:29 map[a:1 b:fast] false
2016年08月18日 23:22:30 map[b:fast a:2] false
2016年08月18日 23:22:31 map[b:slow a:2] true
2016年08月18日 23:22:32 map[a:1 b:fast] false
2016年08月18日 23:22:33 map[a:2 b:slow] true
2016年08月18日 23:22:34 map[a:1 b:slow] true
2016年08月18日 23:22:35 map[a:1 b:slow] true
2016年08月18日 23:22:36 map[a:1 b:slow] true
^Csignal: interrupt</span>



有疑问加站长微信联系(非本文作者)

本文来自:CSDN博客

感谢作者:ylqmf

查看原文:golang context.WithTimeout 超时处理

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
10082 次点击
1 回复 | 直到 2018年07月19日 21:15:01
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏