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

linux定时器时间轮算法

时间轮实现 Linux定时器分为低精度定时器和高精度定时器两种类型,内核对其均有实现。本文讨论的是我们在应用程序开发中比较常见的低精度定时器。...作为常用的基础组件,定时器常用的几种实现方法包括:基于排序链表实现、基于小根堆实现、基于红黑树实现、基于时间轮实现。本文讲解的是时间复杂度最优,也是linux内核采用的基于时间轮的实现方式。...下文从单个时间轮出发讲解,逐步扩展至linux实现定时器所采用的多级时间轮算法。...在 Linux 系统中,我们可以设置slot为1个jiffy(1/HZ)的定时器,假设最大的到期时间范围要达到 2^32个 jiffies,如果采用上面这样的单时间轮,我们就需要2^32个 bucket...Linux时间定时器算法的关键在于添加定时器操作和时间轮进位迁移链表操作。先来说添加定时器。添加定时器的关键又在于知道每个时间轮每一个刻度所能表示的到期时间的范围。

3.3K20

timer定时器用法_定时器怎么调时间

setName(String name) { this.name = name; } public Demo2(String name) { super(); this.name = name; } } 结果:(时间间隔是从任务开始执行计算的...,也就是从当前任务执行的开始时间到下次任务开始时间的间隔是20秒) 3....并且在period后重复执行任务,执行时间是从上次任务结束时间开始计算。凡是带period的都会在时间间隔后重复执行。...在有延时和没有延时的情况下,周期性的任务的下次任务开始时间都是相对于上次任务的开始时间进行延迟(这个在并发编程书中说的是有延迟的情况下相对于结束时间,但是自己测的是相对于开始时间) schedule和...scheduleAtFixedRate的区别在于,如果指定开始执行的时间在当前系统运行时间之前,scheduleAtFixedRate会把已经过去的时间也作为周期执行,而schedule不会把过去的时间算上

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

linux0.11的时间管理和定时器原理

linux初始化的时候,初始化了定时相关的代码。.... // 43是控制字端口,0x36=0x00110110,即二进制,方式3,先读写低8位再读写高8位,选择计算器0 outb_p(0x36,0x43); /* binary, mode 3, LSB...jmp ret_from_sys_call 我们看到中断的时候执行了do_timer函数,该函数就是处理定时器和进程调度的。在此之前我们先看看怎么新增一个定时器。...原理: 每个节点都是以前面一个节点的到时时间为坐标,节点里的jiffies即超时时间 是前一个节点到期后的多少个jiffies后该节点到期。...void do_timer(long cpl) { ... // 当前在用户态,增加用户态的执行时间,否则增加该进程的系统执行时间 if (cpl) current->utime++; else

85020

Linux定时器例子

如果对你有帮助,麻烦点个在看或点个赞,感谢~ 文章首发 公众号—— Pou光明 程序中难免会使用到定时器,今天给大家介绍Linux中一种定时器的实现。...Linux下还有很多其他定时的实现,如精确定时等,感兴趣的同志可以再做深入了解。 编程到现在,其实很多工作都是在调用api,还没能完全脱离面向“谷歌”编程的实质,面对这种情形,如何破局呢?...timerfd_settime() 启动或关闭定时器。 new_value参数指定计时器的初始到期时间和间隔。...struct timespec it_value; /* Initial expiration */ }; 二、用例及封装函数 1、 根据时间间隔创建定时器...三、总结时间 如何理解马克思主义哲学中的对立统一 。。。

3.6K20

Linux定时器实现

时间轮: 但对于Linux这种对定时器依赖性比较高(网络子模块的TCP协议使用了大量的定时器)的操作系统来说,以上的数据结构都是不能满足要求的。所以Linux使用了效率更高的定时器算法:时间轮。...时钟通过时分秒来进行分级,当然我们也可以这样,但对于计算机来说,时分秒的分级不太友好,所以Linux内核中,对32位整型分为5个级别,第一个等级存储0 ~ 255秒 的定时器,第二个等级为 256秒 ~...当要执行到期的定时器只需要移动第一级数组上的指针并且执行该位置上的定时器列表即可,所以时间复杂度为 O(1),而插入一个定时器也很简单,先计算定时器的过期时间范围在哪一级数组上,并且连接到该位置上的链表即可...Linux时间轮的实现 那么接下来我们看看Linux内核是怎么实现时间轮算法的。...每循环一次对第一级数组指针进行加一操作,当第一级数组指针变为0(即所有定时器都执行完),那么就移动下一个等级的指针,并把该位置上的定时器重新计算插入到时间轮中,重新计算定时器通过 cascade_timers

2.9K20

定时器计算工具简介

就像我们的钟表,每经过一秒,数字自动加 1,而这个定时器就是每过一个机器周期的时间,也就是 12/11059200 秒,数字自动加 1。...还有一个特别注意的地方,就是钟表是加到 60 后,秒就自动变成 0 了,这种情况在单片机或计算机里我们称之为溢出。...利用“定时器计算工具”就能够实时计算出定时时间初值,例如,晶振频率设置为12MHz,定时时间为0.1ms。...定时器0采用定时器方式0时,定时器初值:TL0 = 0x9C; TH0 = 0x1F; 定时器0采用定时器方式1时,定时器初值:TL0 = 0x9C; TH0 = 0xFF; 定时器0采用定时器方式...2时,定时器初值:TL0 = 0x9C; 定时器0采用定时器方式3时,定时器初值:TL0 = 0x9C; “定时器计算工具”百度云下载链接: 链接:https://pan.baidu.com/

65730

基于Linux整形时间的常用计算思路

上一次分享了Linux时间时区详解与常用时间函数,相信大家对Linux常见时间函数的使用也有了一定的了解,在工作中遇到类似获取时间等需求的时候也一定能很好的处理。...本文基于Linux整形时间给出一些简化的的常用计算思路,试图从另外的角度去加强读者对时间处理的理解,希望对您有所帮助。 概述 在后台server 的开发中,经常需要基于日期、时间的比较、计算。...计算思路 在Unix/Linux下,系统时间以time_t类型表示,本质上是一个整形数值,数值含义为从历史上的一个基准点开始(格林威治时间1970年1月1日零点),至当前时刻持续的秒数。...在Linux下,time_t被定义long类型,即有符号整型。 考虑到中国与格林威治的时区不同,对中国来说,时间的基准起始点是1970年1月1日早八点整。...通过任意时刻t,我们可以求出其所在当前的零点时间,可以求出所在星期的开始时间,再通过简单的比较,也很容易实现计算出当天星期几等一些相关的扩展,在此不再一一赘述。

1.8K100

Linux】Shell 时间运算以及时间计算方法!

整理:良许Linux 最近一段时间,在处理Shell 脚本时候,遇到时间的处理问题。时间的加减,以及时间差的计算。 1。...时间加减 这里处理方法,是将基础的时间转变为时间戳,然后,需要增加或者改变时间,变成 秒。...如:1990-01-01 01:01:01 加上 1小时 20分 处理方法: a.将基础时间转为时间戳 time1=$(date +%s -d '1990-01-01 01:01:01') echo $...$time2 4800 c.两个时间相加,计算出结果时间 time1=$(($time1+$time2)) time1=$(date +%Y-%m-%d\ %H:%M:%S -d "1970-01-01...时间计算方法 如:2010-01-01 与 2009-01-01 11:11:11 时间差 原理:同样转成时间戳,然后计算天,时,分,秒 time1=$(($(date +%s -d '2010-01

7.4K10

多级时间定时器_时间轮与哈希表定时

因此只要将不同时间定时器按照一定的方法散列到时间轮的不同槽(即时间轮划分的区域)之中,就可以实现在运转到某个槽时,进行判断该定时器是否已经到达运行时间(需要判断是由于有的定时器并非在这一圈就需要运行,...至于在每转到一个槽时都要检查是否到达运行时间,可以这样理解:时间轮进行散列的方法就是取余运算,假设每个槽的间隔为1s,共有n个槽,当前转到了第cur个槽,那么一个定时在 t s以后运行的定时器就要放在第...因此一个槽中的定时器运行的时间是相差i(i >= 0)个周期的。...对实现时间轮来说,最主要的还是链表的操作是否熟练,当然也主要是双向链表的添加与删除。 代码分析 记录定时器时间信息,从而获取在时间轮中槽的位置,以及在多少圈之后被触发。...,时间轮采用双向链表 class TwTimer { public: int rotation; // 定时器转多少圈后生效 int time_slot; // 记录定时器属于时间轮的哪个时间槽 client_data

1.1K20

Linux 内核定时器实验

Linux 时间管理和内核定时器简介 50.1.1 内核时间管理简介 学习过 UCOS 或 FreeRTOS 的同学应该知道, UCOS 或 FreeRTOS 是需要一个硬件定时器 提供系统时钟...同理, Linux 要运行,也是需要一个系统时 钟的,至于这个系统时钟是由哪个定时器提供的,笔者没有去研究过 Linux 内核。...Linux 内核中有大量的函数需要时间管理,比如周期性的调度程序、延时程序、对于我们驱 动编写者来说最常用的定时器。...Linux 内核定时器 采用系统时钟来实现,并不是我们在裸机篇中讲解的 PIT 等硬件定时器。...Linux 内核定时器使 用很简单,只需要提供超时时间(相当于定时值)和定时处理函数即可,当超时时间到了以后设 置的定时处理函数就会执行,和我们使用硬件定时器的套路一样,只是使用内核定时器不需要 做一大堆的寄存器初始化工作

2.1K10

linux内核定时器实验

文章目录 一、linux时间管理和内核定时器简介 1.内核时间管理简介 2.内核定时器简介 1.init_timer 函数 2.add_timer 函数 3.del_timer 函数 4.del_timer_sync...Linux内核也提供了短延时函数,比如 微秒、纳秒、毫秒延时函数,本章我们就来学习一下这些和时间有关的功能。...一、linux时间管理和内核定时器简介 1.内核时间管理简介 Linux 内核中有大量的函数需要时间管理,比如周期性的调度程序、延时程序、对于我们驱动编写者来说最常用的定时器。...Linux 内核定时器采用系统时钟来实现,并不是我们在裸机篇中讲解的 PIT 等硬件定时器。...Linux 内核定时器使用很简单,只需要提供超时时间(相当于定时值)和定时处理函数即可,当超时时间到了以后设置的定时处理函数就会执行,和我们使用硬件定时器的套路一样,只是使用内核定时器不需要做一大堆的寄存器初始化工作

3.5K10
领券