首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux定时器实现

一般定时器实现的方式有以下几种: 基于排序链表方式: 通过排序链表来保存定时器,由于链表是排序好的,所以获取最小(最早到期)的定时器的时间复杂度为 O(1)。...时间轮: 但对于Linux这种对定时器依赖性比较高(网络子模块的TCP协议使用了大量的定时器)的操作系统来说,以上的数据结构都是不能满足要求的。所以Linux使用了效率更高的定时器算法:时间轮。...而时间轮的实现方式与时钟类似,就是把到期时间当成一个轮,然后把定时器挂在这个轮子上面,每当时间走一秒就移动时针,并且执行那个时针上的定时器,如下图: ?...Linux时间轮的实现 那么接下来我们看看Linux内核是怎么实现时间轮算法的。...() 函数实现

2.9K20

Linux内核时钟系统和定时器实现

Linux内核时钟系统和定时器实现 Linux 2.6.16之前,内核只支持低精度时钟,内核定时器的工作方式: 系统启动后,会读取时钟源设备(RTC, HPET,PIT…),初始化当前系统时间; 内核会根据...Linux 2.6.16 ,内核支持了高精度的时钟,内核采用新的定时器hrtimer,其实现逻辑和Linux 2.6.16 之前定时器逻辑区别: hrtimer采用红黑树进行高精度定时器的管理,而不是时间轮...用户层定时器API接口 上面介绍完linux内核定时器实现后,下面简单说一下,基于内核定时器实现的,对用户层开放的定时器API:间隔定时器itimer和POSIX定时器。...3种定时器的类型,如下表所示: 表1 参数which与定时器类型 在Linux 2.6.16 之前,itimer的实现是基于内核定时器timer wheel封装成的定时器接口。...所有这种一级时间轮的实现方式所带来的空间复杂度还是不小的。特别是在需要跨度比较长的定时器时。基于此,就出现了多级时间轮,也就是linux2.6.16之前内核所采用的定时器实现方式。

3.3K30
您找到你想要的搜索结果了吗?
是的
没有找到

Linux定时器例子

如果对你有帮助,麻烦点个在看或点个赞,感谢~ 文章首发 公众号—— Pou光明 程序中难免会使用到定时器,今天给大家介绍Linux中一种定时器实现。...Linux下还有很多其他定时的实现,如精确定时等,感兴趣的同志可以再做深入了解。 编程到现在,其实很多工作都是在调用api,还没能完全脱离面向“谷歌”编程的实质,面对这种情形,如何破局呢?...一、api简介 NAME timerfd_create, timerfd_settime, timerfd_gettime -通过文件描述符来告知定时器状态。...timerfd_settime() 启动或关闭定时器。 new_value参数指定计时器的初始到期时间和间隔。...{ printf("read timerd failed \n"); return -1; } return 0; } 3、通过文件描述符销毁定时器

3.6K20

模拟实现定时器

前言 定时器的功能,就是一个类似于闹钟的到点运行的功能。...一、Timer 类 Java库提供 Timer 类,实现 schedule 方法,给方法提供任务和时间,到时间就运行任务,如: import java.util.Timer; import java.util.TimerTask...二、分析 Timer 类 1)定时器是将多个任务按照时间先后执行,由此一个任务具有任务的具体内容,和执行时间: class TimerTake{ private long time; private...Override public int compareTo(TimerTake o) { return (int)(this.time-o.time); } } 3)为了更好的实现有一个任务实现一个任务...线程安全版本_生产消费者模型_Y君的进化史的博客-CSDN博客),不过考虑到时间先后顺序,采用阻塞优先级队列更加合理,再写一个类MyTimer组织TimerTake类,任务的添加在schedule方法中实现

14720

定时器实现

使用IO定时器 IO定时器每隔1s就会触发一次,从而进入到定时器例程中,如果某个操作是每n秒执行一次(n为正整数)可以考虑在定时器例程中记录一个计数器大小就为n,每次进入定时器例程中时将计数器减一,当计数器为...IO定时器只适合处理整数秒的情况 在使用IO定时器之前需要对定时器进行初始化,初始化函数为IoInitializeTimer,定义如下: NTSTATUS IoInitializeTimer(...PVOID Context//传给定时器例程的函数 ); 初始化完成后可以使用IoStartTimer来启动定时器,使用IoStopTimer来停止定时器,下面是一个例子 #define PAGEDCODE...DISPATCH_LEVEL,所以它不能使用分页内存,所以在函数前加上一句#pragma LOCKEDCODE,表示它在非分页内存中 DPC定时器 DPC定时器相比IO定时器来说更加灵活,它可以指定任何时间间隔...用KeSetTimer开启定时器 3. 在DPC例程中再次调用KeSetTimer开启定时器 4.

83441

Linux 内核定时器实验

Linux 内核定时器 采用系统时钟来实现,并不是我们在裸机篇中讲解的 PIT 等硬件定时器。...在使用内核定时器的时候要注意一点,内核定时器并不是周期 性运行的,超时以后就会自动关闭,因此如果想要实现周期性定时,那么就需要在定时处理函 数中重新开启定时器。...* 或者使用 */ 33 del_timer_sync(&timer); 34 } 50.1.3 Linux 内核短延时函数 有时候我们需要在内核中实现短延时,尤其是在 Linux 驱动中。...在此函数中将 LED 灯的状态取反,实现 LED 灯闪烁的效果。因为内核 定时器不是循环的定时器,执行一次以后就结束了,因此在 161 行又调用了 mod_timer 函数重 新开启定时器。...50.3.3 编写测试 APP 测试 APP 我们要实现的内容如下: ①、运行 APP 以后提示我们输入要测试的命令,输入 1 表示关闭定时器、输入 2 表示打开 定时器,输入 3 设置定时器周期。

2.1K10

JAVA实现定时器功能

在接口开发时,有一种开发模式叫定时器模式,可以理解为每经过一段预设的时间就会执行一次事件,而在我们的工作中,这个事件所实现的功能一般是将两个系统的数据信息进行同步,这样就实现了两个系统通过接口进行对接的功能...下面对于JAVA如何实现定时器功能进行简单的解释 JAVA中有专门可以实现此功能的类:Timer类和TimerTask类 Timer是一种定时器工具,用来在一个后台线程计划执行指定任务,而TimerTask...但是由于每一个Timer对象对应的是单个后台线程,用于顺序执行所有的计时器任务,一般情况下我们的线程任务执行所消耗的时间应该非常短,但是由于特殊情况导致某个定时器任务执行的时间太长,那么他就会“独占”计时器的任务执行线程

1.1K10

FreeRTOS 软定时器实现

定时器是通过一个任务来辅助实现,该功能时刻裁剪的 , 只有设置 FreeRTOSConfig.h 中configUSE_TIMERS == 1 将相关代码编译进来, 才能正常使用相关功能。...Daemon 任务的命令队列深度, 设置定时器都是通过发送消息到该队列实现的。...(--> xTaskGetTickCount()) xTimerGetExpiryTime() 定时器实现 FreeRTOS 软定时器实现在源码目录 Source/include/timers.h,...之后, 定时器Daemon 任务会从消息队列取出消息并响应操作。 命令格式 命令类型 定时器服务任务 此处,从系统启动的定时器Daemon 任务展开分析 FreeRTOS 的软定时器实现 。...命令处理 用户将需要处理的定时器命令发送到定时器的消息队列, Daemon 任务每次执行期间回去读取并执行, 这部分工作有任务主体中的函数 prvProcessReceivedCommands完成, 下面看看这个函数如何实现

1.5K20

Spring中定时器实现

在一些工作需要使用到定时器,Spring很好的集成了定时器的功能!...Quartz,本文介绍Spring3.0以后自主开发的定时任务工具,spring task,可以将它比作一个轻量级的Quartz,而且使用起来很简单,除spring相关的包外不需要额外的包,下面介绍两种方式实现...Spring定时器功能,一种是基于xml配置方式,另外一种是基于注解的方式,大家根据自己的项目选择适合自己的。...总结:这种定时器的使用,不需要集成其他父类定时器,使用简单方便!功能也很强大!...* MON-FRI" 每个周一、周二、周三、周四、周五的10:15触发 三:参考资料 1:Spring定时任务的几种实现 : http://gong1208.iteye.com/blog/1773177

80140

定时器实现原理

1.定时器的作用? 定时器的主要用途是执行定时任务。 定时任务在很多场景都需要用到,比如游戏的 Buff 实现,Redis 中的过期任务,Linux 中的定时任务,电商未支付订单的关闭等等。...2.数据结构要求 定时器需要支持如下几个操作: 创建定时器 添加定时任务 取消定时任务 执行到期任务(查找) 以下为常见实现定时器数据结构的时间复杂度: 有序链表:插入O(n),删除 O(1),过期 expire...,如 libuv 采用最小堆,nginx 采用红黑树,linux 内核和 skynet 采用时间轮算法等等。...5.业界实现方案 业界对于定时器/延迟队列的工程实践,则通常使用以下几种方案。 基于 Redis ZSet 实现。...采用某些自带延迟选项的队列实现,如 RabbitMQ、Beanstalkd、腾讯 TDMQ 等。 基于 Timing-Wheel 时间轮算法实现。 ---- 参考文献 如何快速实现一个定时器

23320

linux内核定时器实验

Linux 内核定时器采用系统时钟来实现,并不是我们在裸机篇中讲解的 PIT 等硬件定时器。...在使用内核定时器的时候要注意一点,内核定时器并不是周期性运行的,超时以后就会自动关闭,因此如果想要实现周期性定时,那么就需要在定时处理函数中重新开启定时器。.../ 33 del_timer_sync(&timer); 34 } 3.linux内核短延时函数 有时候我们需要在内核中实现短延时,尤其是在 Linux 驱动中。...在此函数中将 LED 灯的状态取反,实现 LED 灯闪烁的效果。...3.编写测试APP 测试 APP 我们要实现的内容如下: ①、运行 APP 以后提示我们输入要测试的命令,输入 1 表示关闭定时器、输入 2 表示打开定时器,输入 3 设置定时器周期。

3.5K10

linux定时器时间轮算法

时间轮实现 Linux定时器分为低精度定时器和高精度定时器两种类型,内核对其均有实现。本文讨论的是我们在应用程序开发中比较常见的低精度定时器。...作为常用的基础组件,定时器常用的几种实现方法包括:基于排序链表实现、基于小根堆实现、基于红黑树实现、基于时间轮实现。本文讲解的是时间复杂度最优,也是linux内核采用的基于时间轮的实现方式。...采用有序链表实现定时器,添加定时器的时间复杂度为O(n);采用小根堆或红黑树实现定时器,添加定时器的时间复杂度为O(lgn)。...下文从单个时间轮出发讲解,逐步扩展至linux实现定时器所采用的多级时间轮算法。...Linux定时器到期检查上的操作也实现得很巧妙。假设curr_time=0x12345678,那么下一个检查的时刻为0x12345679。

3.3K20

定时器实现原理剖析

本文讲述Go中时间相关函数的使用和实现原理,时间相关的源码在src下的time包和runtime包,下面的分析基于的Go的1.14版本。...在Go中,定时器并不是通过sigalarm signal实现的,而是通过堆(四叉堆)实现的。...r是timer的真正实现结构体,在runtime包中也有一个timer定义,与这里的runtimeTimer结构是一模一样的。timer的真正实现逻辑是在runtime包处理的。...然后执行startTimer启动定时器,startTime真正实现在runtime包中的time.go中 // 创建一个定时器timer结构,可以在d duration后从timer的通道中读取通知信息...,启动新的M处理定时器 if next < now { startm(nil, false) } ... } 总结 上述分析的是1.14版的定时器实现原理,在1.14版本之前,定时器实现方法与上面不太一样

89040
领券