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. hadoop 环境配置

    HADOOP_HOME E:\tool\eclipse\hadoop-2.7.3 HADOOP_USER_NAME ambari-qa path: %HADOOP_HOME%/bin

  2. java编程思想 内容总结

    Java编程思想重点笔记(Java开发必看) Java编程思想,Java学习必读经典,不管是初学者还是大牛都值得一读,这里总结书中的重点知识,这些知识不仅经常出现在各大知名公司的笔试面 试过程中,而且 ...

  3. UVA 11880 Ball in a Rectangle(数学+平面几何)

    Input: Standard Input Output: Standard Output � There is a rectangle on the cartesian plane, with bo ...

  4. Python调用MYSQL,将文件名和路径批量入库用法小结

    最近项目需要将大量的压缩文件导入到数据库中,所以开始总结用Python批量处理的办法,本次是首先将这些压缩文件的文件名提取出来,然后导入到数据库中. 由于涉及到路径的读取处理,所以方法有os模块和co ...

  5. 用Electron开发桌面应用app的相关文献集锦

    1. 超棒的发声器(项目实战) 原文点此链接 2. Electron中文文档 原文点此链接

  6. [UVA1625]Color Length

    题面在这里 description 输入两个长度分别为\(n\)和\(m\)的颜色序列,要求按顺序合并成同一个序列,即每次可以把一个序列开头的颜色放到新序列的尾部. 对于每个颜色\(c\)来说,其跨度 ...

  7. mysql的增量备份

    1,在mysql 的my.ini文件中 2在我的D盘下创建binlog文件夹 3重启mysql服务可以看到我的D盘下的binlog下生成如下文件 4,在默认的test数据库中创建t_one1这张表 c ...

  8. Asp.net MVC Combres的简单用法

    第一步:添加nuget包 [1]添加 nuget包后,会自动在 webconfig里面 添加配置文件(不用改) <section name="dotless" type=&q ...

  9. springboot中 后端跨域的实现配置

    在springboot的启动文件中,添加此内容,可以允许跨域

  10. Codis+redis 集群测试

    Codis 是一个分布式 Redis 解决方案, 对于上层的应用来说, 连接到 Codis Proxy 和连接原生的 Redis Server 没有显著区别 (不支持的命令列表), 上层应用可以像使用 ...