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. LeetCode 234——回文链表

    1. 题目 请判断一个链表是否为回文链表. 示例 1: 输入: 1->2 输出: false 示例 2: 输入: 1->2->2->1 输出: true 进阶: 你能否用 O( ...

  2. HDU 4745 Two Rabbits(最长回文子序列)(2013 ACM/ICPC Asia Regional Hangzhou Online)

    Description Long long ago, there lived two rabbits Tom and Jerry in the forest. On a sunny afternoon ...

  3. LTE:上行调度请求(Scheduling Request,SR) LTE:下行资源分配类型

    http://blog.sina.com.cn/s/blog_927cff010101a7yh.html 上行调度请求(Scheduling Request,SR) 如果UE没有上行数据要传输,eNo ...

  4. D - 小木棒

    D - 小木棒 Time Limit: 1000/1000MS (C++/Others) Memory Limit: 65536/65536KB (C++/Others) Problem Descri ...

  5. 【EasyNetQ】- 使用Future Publish调度事件

    许多业务流程要求在将来某个日期安排事件.例如,在与客户进行初次销售联系后,我们可能希望在将来的某个时间安排跟进电话.EasyNetQ可以通过其Future Publish功能帮助您实现此功能.例如,这 ...

  6. [剑指Offer] 30.连续子数组的最大和

    题目描述 HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学.今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决.但是,如果向量 ...

  7. LeetCode -- Tiangle

    Question: Given a triangle, find the minimum path sum from top to bottom. Each step you may move to ...

  8. 我的emacs配置部分

    考场必记8行 (global-set-key (kbd "RET") 'newline-and-indent)//换行 (global-set-key (kbd "C-a ...

  9. [luoguP3644] [APIO2015]八邻旁之桥(权值线段树)

    传送门 首先如果起点终点都在同一侧可以直接处理,如果需要过桥答案再加1 对于k等于1的情况 桥的坐标为x的话,a和b为起点和终点坐标 $ans=\sum_{1}^{n} abs(a_{i}-x)+ab ...

  10. 洛谷 P2894 [USACO08FEB]酒店Hotel 解题报告

    P2894 [USACO08FEB]酒店Hotel 题目描述 The cows are journeying north to Thunder Bay in Canada to gain cultur ...