package main

import (
	"fmt"
	"time"
)

func main(){
	//创建一个定时器,时间为2s,2s过后会自动往通道里面写入数据
	//数据只会写一次
	timer := time.NewTimer(2 * time.Second)
	fmt.Println("当前时间", time.Now())//当前时间 2018-09-11 21:47:46.1274704 +0800 CST m=+0.001994901

	//2s后,timer.C里面会有数据可以读
	t := <-timer.C//没有数据前会阻塞
	fmt.Println("现在时间",t)//现在时间 2018-09-11 21:47:48.1280881 +0800 CST m=+2.002612601
}

  

package main

import (
	"fmt"
	"time"
)

//实现延时功能
func main(){
	//1.延时两秒钟打印一句话
	timer:= time.NewTimer(time.Second * 2)
	fmt.Println("------")//注意这里是不会卡住的,time.Newtimer()执行完是不会等待的,会直接往下走
	<- timer.C //这里是会卡住,因为必须要等两秒后,timer.C里面有数据才行
	fmt.Println("------")

	//2.延时两秒钟打印一句话
	time.Sleep(time.Second * 2)
	fmt.Println("------")

	//3.延时两秒钟打印一句话
	//注意:NewTimer会有一个返回值(timer),数据写在了timer.C里面,我们需要往timer.C里面读取数据
	//但是After本身就直接返回一个通道,两秒后往通道里面写数据,所以我们直接从After这里读取数据即可
	//先是没有数据,然后等两秒后,数据写入,就可以读了
	<- time.After(time.Second * 2)
	fmt.Println("------")
}

  

package main

import (
	"fmt"
	"time"
)

//定时器停止
func main(){
	//3s后,time.C里面会有数据可以读
	timer:=time.NewTimer(time.Second * 3)
	//注意这里是不会阻塞的,当遇见time.C才会阻塞
	go func() {
		<-timer.C
		fmt.Println("子协程可以打印了")
	}()
	timer.Stop()//当我停止了定时器,子协程里面变无法再往下执行了,所以是不会有打印结果的

	//让主协程不停下
	for{

	}
}

  

package main

import (
	"fmt"
	"time"
)

//定时器重置
func main(){
	//3s后,time.C里面会有数据可以读
	timer:=time.NewTimer(time.Second * 3)
	//这里我重置定时器,那么上面的3s便无效了,因此会在一秒钟之后打印
	timer.Reset(time.Second * 1)
	<- timer.C
	fmt.Println("时间到")
}

  

package main

import (
	"fmt"
	"time"
)

//ticker的使用
func main(){
	//和timer不一样,ticker是周期性的循环,像闹钟一样
	ticker:=time.NewTicker(time.Second * 1)
	i:=0
	for {
		<-ticker.C
		i++
		fmt.Println("i=",i)
		if i==9{
			break
		}
	}
}
/*
i= 1
i= 2
i= 3
i= 4
i= 5
i= 6
i= 7
i= 8
i= 9
 */

  

go语言的定时器的更多相关文章

  1. 模仿linux内核定时器代码,用python语言实现定时器

    大学无聊的时候看过linux内核的定时器,如今已经想不起来了,也不知道当时有没有看懂,如今想要模仿linux内核的定时器.用python写一个定时器,已经想不起来它的设计原理了.找了一篇blog,li ...

  2. Go语言中定时器cron的基本使用

    安装:go get github.com/robfig/cron  如果出不去就用gopm 例子: package main import ( "fmt" "github ...

  3. 08. Go 语言包(package)

    Go 语言包(package) Go 语言的源码复用建立在包(package)基础之上.Go 语言的入口 main() 函数所在的包(package)叫 main,main 包想要引用别的代码,必须同 ...

  4. golang 日期时间处理

    package main import ( "fmt" "time" ) func main() { fmt.Println(time.Now()) //显示时 ...

  5. golang:协程安全

    多路复用 Go语言中提供了一个关键字select,通过select可以监听channel上的数据流动.select的用法与switch语法类似,由select开始一个新的选择块,每个选择条件由case ...

  6. linux c语言定时器

    原文来自于:http://hi.baidu.com/opetrhsxszbckzd/item/126966cae5f9524aa9ba94f5 我只是把其重新排版标注一下. linux c语言定时器 ...

  7. Go语言学习之8 goroutine详解、定时器与单元测试

    主要内容: 1.Goroutine2. Chanel3. 单元测试 1. Goroutine Go 协程(Goroutine)(轻量级的线程,开线程没有数量限制).   (1)进程和线程 A. 进程是 ...

  8. C语言实现的多线程定时器

    目录 1. 大致功能介绍 2. API库介绍 3. 一个例子 4. 库文件源码 注意事项 1. 大致功能介绍 实现任务列表,定时器会间隔一段时间遍历列表发现要执行的任务 任务列表中的所有任务并行执行 ...

  9. 经典多级时间轮定时器(C语言版)

    经典多级时间轮定时器(C语言版) 文章目录 经典多级时间轮定时器(C语言版) 1. 序言 2. 多级时间轮实现框架 2.1 多级时间轮对象 2.2 时间轮对象 2.3 定时任务对象 2.4 双向链表 ...

随机推荐

  1. 容器基础(十): 使用kubernetes部署应用

    概述 使用之前的脚本(env/server.py 得到 env/server:v0.1 镜像, env/worker.py 得到 env/worker:v0.1)得到的镜像,在部署好kubernete ...

  2. sysctl -P 报错解决办法 error: "net.bridge.bridge-nf-call-ip6tables" is an unknown key

    error: "net.bridge.bridge-nf-call-ip6tables" is an unknown keyerror: "net.bridge.brid ...

  3. week12第二轮迭代任务分配forZ.XML

    Z.XML第二轮迭代任务初步分配新鲜出炉,请关注! 以上便是任务分配列表,队员们会按照进度每天更改任务进度 当然,根据敏捷开发的方法,我们将在开发过程中根据情况迅速调整任务分配,以适应当时问题. Z- ...

  4. websocket协议详解;

    websocket是基于http协议,借用http协议来完成连接阶段的握手: 当连接建立后,浏览器和服务器之间的通信就和http协议没有关系了,b.s之间只用websocket协议来完成基本通信. = ...

  5. 第一个Spring小程序实战

    ps:本文偏向原理和操作性,原理适合于任何编译器. 支持Spring入门,目的是在xml文件里面装配相关bean(java对象),并实现获取.(IOC) 一.先建立一个Spring新项目,添加mave ...

  6. Pandoc中的Markdown语法

    概述 Pandoc中支持扩展修订版本的Markdown语法 使用pandoc中支持的Markdown语法用 -f markdown 使用标准Markdown语法用 -f markdown_strict ...

  7. 算法(5)Jump Game

    题目:非负数的数组,每个数组元素代表这你能最大跨越多少步,初始在0的位置,问,能不能正好调到数组的最后一位! https://leetcode.com/problems/jump-game/#/des ...

  8. 【python】python 中的三元表达式(三目运算符)

    python中的三目运算符不像其他语言其他的一般都是 判定条件?为真时的结果:为假时的结果 如 result=5>3?1:0 这个输出1,但没有什么意义,仅仅是一个例子.而在python中的格式 ...

  9. ES mapping的写入与查看

    Elasticsearch索引mapping的写入.查看与修改 https://blog.csdn.net/napoay/article/details/52012249 首先创建一个索引: curl ...

  10. 【bzoj1257】[CQOI2007]余数之和sum 数论

    题目描述 给出正整数n和k,计算j(n, k)=k mod 1 + k mod 2 + k mod 3 + … + k mod n的值,其中k mod i表示k除以i的余数.例如j(5, 3)=3 m ...