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

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

Linux定时器实现

一般定时器实现的方式有以下几种: 基于排序链表方式: 通过排序链表来保存定时器,由于链表是排序好的,所以获取最小(最早到期)的定时器的时间复杂度为 O(1)。...时间轮: 但对于Linux这种对定时器依赖性比较高(网络子模块的TCP协议使用了大量的定时器)的操作系统来说,以上的数据结构都是不能满足要求的。所以Linux使用了效率更高的定时器算法:时间轮。...时钟通过时分秒来进行分级,当然我们也可以这样,但对于计算机来说,时分秒的分级不太友好,所以Linux内核中,对32位整型分为5个级别,第一个等级存储0 ~ 255秒 的定时器,第二个等级为 256秒 ~...注意:第二级至第五级数组的第一个槽是不挂任何定时器的。 每级数组上面都有一个指针,指向当前要执行的定时器。每当时间走一秒,Linux首先会移动第一级的指针,然后执行当前位置上的定时器。...Linux时间轮的实现 那么接下来我们看看Linux内核是怎么实现时间轮算法的。

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

linux定时器时间轮算法

时间轮实现 Linux定时器分为低精度定时器和高精度定时器两种类型,内核对其均有实现。本文讨论的是我们在应用程序开发中比较常见的低精度定时器。...下文从单个时间轮出发讲解,逐步扩展至linux实现定时器所采用的多级时间轮算法。...Linux定时器时间轮分为5个级别的轮子(tv1 ~ tv5),如图3所示。每个级别的轮子的刻度值(slot)不同,规律是次级轮子的slot等于上级轮子的slot之和。...Linux时间轮定时器算法的关键在于添加定时器操作和时间轮进位迁移链表操作。先来说添加定时器。添加定时器的关键又在于知道每个时间轮每一个刻度所能表示的到期时间的范围。...Linux定时器到期检查上的操作也实现得很巧妙。假设curr_time=0x12345678,那么下一个检查的时刻为0x12345679。

3.3K20

简单谈谈Linux内核定时器

软件意义上的定时器最终依赖硬件定时器来实现, 内核在时钟中断发生后检测各定时器是否到期 , 到期后的定时器处理函数将作为软中断在底半部执行 。...总结起来还是软中断的流程 a.注册软中断处理函数 /*/linux/kernel.timer.c*/ void __init init_timers(void) -->open_softirq(TIMER_SOFTIRQ...在Linux设备驱动编程中,可以利用Linux内核中提供的一组函数和数据结构来完成定时触发工作或者完成某种周期性的事务。...1) 一个timer_list 结构体的实例对应一个定时器,其定义如下: struct timer_list {    struct list_head entry, /*定时器列表*/    unsigned...long expires, /*定时器到期时间*/    void (*function) (unsigned long), /*定时器处理函数*/    unsigned long data,/*作为参数被传入定时器处理函数

2.5K32

Linux驱动开发-内核定时器

内核定时器介绍 内核定时器是内核用来控制在未来某个时间点(基于jiffies(节拍总数))调度执行某个函数的一种机制,相关函数位于 和 kernel/timer.c 文件中...函数参数 timer:对应的定时器结构体 expires:超时时间 函数返回值 成功返回 :修改成功的时间值 函数定义文件 \linux-3.5\kernel\timer.c 2.2 初始化定时器...函数原型 #define init_timer(timer)\ 函数功能 初始化定时器结构 函数参数 timer:对应的定时器结构体 函数定义文件 \linux-3.5\include\linux\timer.h...函数参数 timer:对应的定 时器结构体 函数返回值 返回0:成功 函数定义文件 \linux-3.5\include\linux\timer.h 2.4 关闭定时器 函数原型 int del_timer_sync...init_timer(&mytimer); /*初始化定时器*/ add_timer(&mytimer); /*启动定时器*/ 完整示例代码: #include <linux

2.7K50

10_linux内核定时器实验

一、linux时间管理和内核定时器简介 1、内核时间管理简介 1)宏HZ ​ 硬件定时器产生的周期性中断,中断频率就是系统频率(拍率)。...内核使用 timer_list 结构体来表示内核定时器,timer_list 定义在 include/linux/timer.h 中: struct timer_list { struct...② add_timer函数 ​ add_timer 函数用于向 Linux内核注册定时器,使用 add_timer 函数向内核注册定时器以后,定时器就会开始运行,函数原型如下: void add_timer...return ret; } /* * @description : ioctl函数, * @param – filp : 要打开的设备文件(文件描述符) * @param - cmd : 应用程序发送过来的命令...License 和作者信息 ​ 驱动的 License 是必须的,缺少的话会报错,在文件最末端添加以下代码: MODULE_LICENSE("GPL"); MODULE_AUTHOR("lzk"); 三、编写测试应用程序

1.9K30

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 上使用 systemd 设置定时器

定时器增加了另一种启动服务的方式,基于……时间。尽管与定时任务很相似,但 systemd 定时器稍微地灵活一些。让我们看看它是怎么工作的。...你将通过创建一个定时器来“改进” Minetest 服务器,使得在服务器启动 1 分钟后运行游戏服务器而不是立即运行。...其他的指令有: OnActiveSec=,告诉 systemd 在定时器启动后多长时间运行服务。...OnUnitActiveSec=,告诉 systemd 在上次由定时器激活的服务启动后多长时间运行服务。...你也可以检查系统上所有的定时器何时运行或是上次运行的时间: systemctl list-timers --all 图 2:检查定时器何时运行或上次运行的时间 最后一件值得思考的事就是你应该用怎样的格式去表示一段时间

1.6K10

1s看懂555定时器,以及应用

555定时器是美国Signetics公司1972年研制的用于取代机械式定时器的中规模集成电路,因输入端设计有三个5kΩ的电阻而得名。此电路后来竟风靡世界。...应用范围包括定时器,脉冲丢失检测,反弹跳开关,轻触开关,分频器,电容测量,脉冲宽度调制(PWM)等 无稳态模式 在此模式下,555以振荡器的方式工作。...其中第1个单元电路(3.2.1)是应用最广的。第2个单元电路(3.2.2)是方波振荡电路。...实际应用电路 555触摸定时开关 集成电路IC1是一片555定时电路,在这里接成单稳态电路。...相片曝光定时器 附图电路是用555单稳电路制成的相片曝光定时器。用人工启动式单稳电路。 工作原理: 电源接通后,定时器进入稳态。此时定时电容CT的电压为:VCT=VCC=6V。

1.4K20

单片机入门:定时器计数器应用

利用单片机内部定时器/计数器中断实现一个数码管的秒记数,重点学习定时器/计数器的工作方式以及其控制寄存器TMOD、TCON的功能,在程序实现过程中掌握定时器/计数器中断的一般步骤。...51单片机内部含有两个定时器/计数器,分别是T0和T1,在增强型51系列单片机中,如STC89C51RC,内部除了含有T0和T1外,还有T2定时器/计数器。...定时器/计数器主要由于精确的定时,也可用于对外部脉冲进行计数以及为作为串行通信的波特发生器。定时/计数器不同的功能是通过对相关特殊功能寄存器的设置和程序设计来实现的。...TR0 = 0; //设置计时器控制寄存器TCON寄存器的TR0位为0,Timer0停止计数 TL0 = (65536 - 5000) % 256; //设置定时器的低8位初值...,计5000个机器周期脉冲就会溢出 TH0 = (65536 - 5000) / 256;; //设置定时器的高8位初值,假设单片机晶振为12MHz。

54620

Java 定时器_Javaweb定时器

上篇提到了 阻塞队列,本篇我们将优先级队列和阻塞队列结合,得到 阻塞优先队列,以此来实现一个定时器~ 定时器 定义 应用场景 定时器的实现: 定时器构成 代码实现: 代码分析: 忙等 一处唤醒,两处阻塞...附最终全部代码: 完整的执行过程: 定义 定时器,是多线程编程中的一个重要 / 常用组件 定时器可以强制终止请求:浏览器内部都有一个定时器,发送请求后,定时器就开始计时;若在规定时间内,响应数据没有返回...,就会强制终止请求 定时器,有些逻辑不想立刻执行,而是要等一定的时间之后,再来执行 好比一个闹钟,在我们设定好闹钟时间后,到时间闹钟就会自动响起,无论设置闹钟时间的前后,设置的哪个时间先到就先响起 应用场景...定时器应用场景非常广泛,网络编程中特别常见 画图举例: 浏览器中的定时器,时间单位一般是 s 服务器中的定时器,时间单位一般是 ms 定时器可以强制终止请求:浏览器内部都有一个定时器,发送请求后...,定时器就开始计时;若在规定时间内,响应数据没有返回,就会强制终止请求 定时器的实现: 定时器构成 使用一个类来描述”一段逻辑” (一个要执行的任务 task ),同时也要记录该任务在啥时候来执行 使用一个阻塞优先队列来组织若干个任务

2.4K21
领券