CN104035786B - 一种软件定时器的优化方法及系统 - Google Patents

一种软件定时器的优化方法及系统 Download PDF

Info

Publication number
CN104035786B
CN104035786B CN201410309635.XA CN201410309635A CN104035786B CN 104035786 B CN104035786 B CN 104035786B CN 201410309635 A CN201410309635 A CN 201410309635A CN 104035786 B CN104035786 B CN 104035786B
Authority
CN
China
Prior art keywords
timer
time
array
linked list
module
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201410309635.XA
Other languages
English (en)
Other versions
CN104035786A (zh
Inventor
李梅勇
原曦佳
邓惩
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Shaanxi Green Water Technology Co ltd
Original Assignee
Shanghai Feixun Data Communication Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Shanghai Feixun Data Communication Technology Co Ltd filed Critical Shanghai Feixun Data Communication Technology Co Ltd
Priority to CN201410309635.XA priority Critical patent/CN104035786B/zh
Publication of CN104035786A publication Critical patent/CN104035786A/zh
Application granted granted Critical
Publication of CN104035786B publication Critical patent/CN104035786B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Debugging And Monitoring (AREA)

Abstract

本发明提供一种软件定时器的优化方法,包括:创建第一和第二定时器数组;定义总运行时间T1和每个时刻所有定时器实例对象超时处理所需时间T2,初始化T1和所述T2为零;等待时间片后,总运行时间T1加1,记录T1’;根据链表索引号将定时器实例对象添加至第一定时器数组的链表数组元素,检测定时器实例对象的超时,记录超时时间T3,生成索引时刻;根据索引时刻将与其对应的定时器实例对象添加至第二定时器数组的链表数组元素;在第二定时器数组中循环执行超时回调处理函数,之后删除该定时器实例对象,直至执行完毕所有定时器实例对象。本发明提高定时器实例对象的操作效率,极大的减少CPU的占用率,对定时器进行时间漂移补偿,提高定时器的定时准确度。

Description

一种软件定时器的优化方法及系统
技术领域
本发明计算机通信技术领域,涉及一种优化方法及系统,特别是涉及一种软件定时器的优化方法及系统。
背景技术
嵌入式多任务系统软件设计中经常会用到定时器,分为硬件定时器和软件定时器。硬件定时器通过中断方式实现,时间准确度高,但使用限制较多,如超时处理函数有阻塞,定时器较多时多中断对系统性能有影响。而传统的软件定时器通过一个软件定时器链表去管理定时器实例对象的所有操作,包括定时器实例对象的创建,启动,超时检测及处理,停止及删除。每次超时判断都会去循环遍历扫描链表中所有的定时器实例对象是否有超时,将超时的所有定时器进行相应回调处理,若果定时器实例对象应用较多,成百上千时,会占用很大的cpu资源,对定时器的管理效率低,且同一时刻超时的定时器会较多,执行这些超时定时器的回调处理耗时总合也会较多,由于这部分耗时未计算在软件定时器计时中,长期累积将会造成软件定时器时间偏移,定时不准确的问题。
由于在软件开发中经常需要用到定时器,特别是在通信系统的设计中,有大量的定时要求。如在机架式EPON系统设计中,统计模块需要针对每个监控点启动定时器去定时采集数据,监控点可能上百个。在组播等协议模块中,收发包都需要用到定时器:发送消息以后有时候需要对方在约定的时间内收到对方的回应,如果在规定的时间内收不到回应,需要进行适当的处理,或者重发消息,或者进入出错处理。这些都对定时时间都较高要求。
对于通用的定时器管理方法来说,以下操作都是必须的:
1)创建定时器,creatTimer(interval,*app_callback)。设置一个定时器实例,其中interval表示定时器的指定时长,*app_callback表示定时器超时的回调处理函数。函数返回一个可用的定时器标识ID(timer ID);
2)启动定时器,startTimer(timer ID)。启动一个定时器实例,其中timerID为定时器的唯一标识;
3)停止定时器,stopTimer(timer ID)。停止一个定时器实例,其中timerID为定时器的唯一标识;
4)删除定时器,destroyTimer(timerID)。在定时器超时前,根据已知的timerID查找到定时器实例对象,并将其删除;
5)超时检查和处理。将定时器的时长划分为若干个时间相等的时间片,在每个时间片内检查所管理的定时器实例是否有超时,如果有,则触发超时处理。检测定时器的超时,并进行超时回调处理。
现有技术采用一个链表timerList来管理定时器实例对象的所有操作。给定超时时间t1,t2,t3及相应的超时回调处理函数,创建定时器实例索引timer1,timer2,timer3,请参阅图1,显示为现有技术中定时器实例索引存储示意图。设置相应的剩余超时时间(timeout_interval)为t1,t2,t3。启动定时器时将定时器实例对象timer1,timer2,timer3按启动顺序添加到定时器管理链表timerList中。停止定时器实例对象及删除定时器实例对象时从定时器管理链表timerList开头扫描找到要处理的定时器实例对象进行相应处理。
现有定时器实例对象的超时检测和处理过程如下:
初始化创建一个定时器处理任务,该任务执行一个死循环:先定时等待一个时间片(timerTick)(一般用类taskDelay的系统调用),接下来将timerList链表头指针的第一个定时器实例索引timer1的剩余时间timeout_interval减去时间片timerTick,然后判断timeout_interval是否大于0。如果不大于0则说明这个定时器超时,执行相应的超时回调处理函数,并将这个定时器实例索引从链表中删除。因为可能有多个定时器同时超时,因此第一个定时器实例索引处理完以后,还需要继续扫描该定时器实例索引的下一个定时器实例索引,执行同样的操作,直到遍历到链表结尾为止。
针对现有计数定时方案,对定时器的开启,停止及删除等操作处理以及定时器超时检测处理都是通过扫描整个定时器链表完成的,当定时器实例对象较多时,比较消耗CPU资源。更严重的问题是在定时器处理任务中,每次时间片timerTick到时时,就必须去扫描所有的定时器实例对象,而时间片到时间隔一般会很小(1个tick或1s),这样将会很占用CPU资源,对系统的整体性能和稳定性带来的弊端。而且当同一时刻超时的定时器过多,执行定时器的处理回调函数比较耗时时,耗时累积比较大,由于定时器未考虑这部分耗时,会造成定时器时间偏移,定时不准,会对一些协议模块等对时间要求较高的模块造成影响,严重时会影响这些模块的正常功能等。
发明内容
鉴于以上所述现有技术的缺点,本发明的目的在于提供一种软件定时器的优化方法及系统,用于解决现有技术中定时器实例对象过多时对定时器的管理效率低,大量占用CPU资源,且定时器超时回调处理过程中的时间偏移导致定时时间不准确的问题。
为实现上述目的及其他相关目的,本发明一方面提供一种软件定时器的优化方法,应用于若干个需要使用定时器的业务模块中,每一个业务模块包括多个定时器实例对象,包括:步骤一,为每一个需要使用定时器的业务模块生成定时器链表索引号,创建包括与所述业务模块数量一致的链表数组元素的第一定时器数组;定义总运行时间,记录为T1和每个时刻所有定时器实例对象超时处理所需时间,记录为T2,初始化所述T1和所述T2为零;所述定时器实例对象包括定时器超时回调处理函数;步骤二,等待一时间片后,所述总运行时间T1自动加1,记录第一总运行时间T1’;步骤三,开启所述业务模块中的定时器实例对象,根据所述定时器链表索引号将所述业务模块包括的多个定时器实例对象添加至所述第一定时器数组的链表数组元素中;步骤四,创建第二定时器数组,在所述第二定时器数组检测所述定时器实例对象的超时,记录该定时器实例对象的超时时间T3,生成由该定时器实例对象的超时时间T3与第一总运行时间T1’之和组成的索引时刻;步骤五,根据所述索引时刻将与所述索引时刻相对应的定时器实例对象添加至所述第二定时器数组的链表数组元素中;步骤六,在所述第二定时器数组中循环执行所述链表数组元素下的定时器实例对象的超时回调处理函数,执行完后删除该定时器实例对象,继续执行该定时器实例对象下的其他定时器实例对象,直至执行完毕该链表数组元素下所有定时器实例对象,继续下一次循环。
优选地,所述软件定时器的优化方法还包括:判断所述索引时刻是否小于等于第一总运行时间T1’与所有定时器实例对象超时处理所需时间T2之和,若是,则执行下一步骤,若否,则记录第二总运行时间T1”;判断所述第二定时器数组的链表数组元素中是否存在定时器实例对象,若是,则执行下一步骤,若否,则返回步骤二,重新运行所述软件定时器的优化方法;若所述链表数组元素中存在定时器实例对象,则在所述第二定时器数组中循环执行所述链表数组元素的定时器实例对象的定时器超时回调处理函数,之后删除该定时器实例对象。
优选地,所述软件定时器的优化方法还包括:判断该定时器实例对象下是否还存在其他定时器实例对象,若是,则执行超时回调处理函数的步骤,若否,则记录第二总运行时间T1”;判断第二总运行时间T1”与记录第一总运行时间T1’之差是否大于所述时间片,若否,则表示为所有定时器实例对象超时处理所需时间T2赋值为零,若是,则表示为所有定时器实例对象超时处理所需时间T2赋值为为T1”-T1’,继续下一次循环。
优选地,所述定时器实例对象还包括记录存在于所述第一定时器数组中链表数组元素的节点的第一节点指针、记录存在于所述第二定时器数组中链表数组元素的节点的第二节点指针、及定时器超时回调处理参数。
优选地,所述定时器实例对象中的第一节点指针记录所述第一定时器数组中所述链表数组元素的首地址。所述定时器实例对象中的第二节点指针记录所述第二定时器数组中链表数组元素的首地址。
优选地,所述步骤六还包括根据所述定时器实例对象中的第一节点指针在所述第一定时器数组中删除所述定时器实例对象。
优选地,所述第一定时器数组为定时器管理链表数组,所述第二定时器数组为定时器超时检测处理链表数组。
本发明另一方面还提供一种软件定时器的优化系统,应用于若干个需要使用定时器的业务模块中,每一个业务模块包括多个定时器实例对象,包括:第一创建模块,用于为每一个需要使用定时器的业务模块生成定时器链表索引号,创建包括与所述业务模块数量一致的链表数组元素的第一定时器数组;定义总运行时间,记录为T1和每个时刻所有定时器实例对象超时处理所需时间,记录为T2,初始化所述T1和和所述T2为零;所述定时器实例对象包括定时器超时回调处理函数;且所述第一创建模块还用于等待一时间片后,为所述总运行时间T1自动加1,记录第一总运行时间T1’;管理模块,用于开启所述业务模块中的定时器实例对象,根据所述定时器链表索引号将所述业务模块包括的多个定时器实例对象添加至所述第一定时器数组的链表数组元素中;第二创建模块,用于创建第二定时器数组,在所述第二定时器数组检测所述定时器实例对象的超时,记录该定时器实例对象的超时时间T3,生成由该定时器实例对象的超时时间T3与第一总运行时间T1’之和组成的索引时刻;所述管理模块还用于根据所述索引时刻将与所述索引时刻相对应的定时器实例对象添加至所述第二定时器数组的链表数组元素中;处理模块,用于在所述第二定时器数组中循环执行所述链表数组元素下的定时器实例对象的超时回调处理函数,执行完后删除该定时器实例对象,继续执行该定时器实例对象下的其他定时器实例对象,直至执行完毕该链表数组元素下所有定时器实例对象。
优选地,所述软件定时器的优化系统还包括:第一判断模块和第二判断模块;其中,所述第一判断模块用于判断所述索引时刻是否小于等于第一总运行时间T1’与所有定时器实例对象超时处理所需时间T2之和,若是,则调用所述第二判断模块,若否,则调用所述第二创建模块记录第二总运行时间T1”;所述第二判断模块用于判断所述第二定时器数组的链表数组元素中是否存在定时器实例对象,若是,调用所述处理模块,若否,则重新运行所述软件定时器的优化系统;所述处理模块用于若所述链表数组元素中存在其他定时器实例对象,则在所述第二定时器数组中循环执行所述链表数组元素的定时器实例对象的定时器超时回调处理函数,之后删除该定时器实例对象。
优选地,所述软件定时器的优化系统还包括:第三判断模块和第四判断模块;其中,所述第三判断模块用于判断该定时器实例对象下是否还存在其他定时器实例对象,若是,则继续调用所述处理模块,执行超时回调处理函数的步骤,若否,则调用所述第二创建模块记录第二总运行时间T1”;所述第四判断模块用于判断第二总运行时间T1”与记录第一总运行时间T1’之差是否大于所述时间片,若否,则表示为所有定时器实例对象超时处理所需时间T2赋值为零,若是,则表示为所有定时器实例对象超时处理所需时间T2赋值为T1”-T1’,继续下一次循环。
如上所述,本发明的软件定时器的优化方法及系统,具有以下有益效果:
第一,本发明所述的软件定时器的优化方法及系统由于此设计按照模块划分定时器实例对象,提高了定时器实例对象的操作效率。对定时器按照超时时间添加到定时器超时检测处理数组中,每个时刻只会去访问处理当前时刻已超时的定时器实例对象,不需访问所有定时器实例对象,极大的减少的CPU的占用率。
第二,同时本发明所述的软件定时器的优化方法及系统对定时器对象的超时回调处理进行了耗时计算,对定时器进行了时间漂移补偿,提高了定时器的定时准确度。
附图说明
图1显示为现有技术中定时器实例索引存储示意图示意图。
图2显示为本发明的软件定时器的优化方法的流程图。
图3显示为本发明的具体实施方式第一定时器数组中定时器实例对象存储示意图。
图4显示为本发明的具体实施方式第二定时器数组中定时器实例对象存储示意图。
图5显示为本发明的软件定时器的优化系统的原理结构图。
元件标号说明
1 软件定时器的优化系统
11 第一创建模块
12 管理模块
13 第二创建模块
14 处理模块
15 第一判断模块
16 第二判断模块
17 第三判断模块
18 第四判断模块
19 赋值模块
S1~S14 步骤
具体实施方式
以下通过特定的具体实例说明本发明的实施方式,本领域技术人员可由本说明书所揭露的内容轻易地了解本发明的其他优点与功效。本发明还可以通过另外不同的具体实施方式加以实施或应用,本说明书中的各项细节也可以基于不同观点与应用,在没有背离本发明的精神下进行各种修饰或改变。需说明的是,在不冲突的情况下,以下实施例及实施例中的特征可以相互组合。
需要说明的是,以下实施例中所提供的图示仅以示意方式说明本发明的基本构想,遂图式中仅显示与本发明中有关的组件而非按照实际实施时的组件数目、形状及尺寸绘制,其实际实施时各组件的型态、数量及比例可为一种随意的改变,且其组件布局型态也可能更为复杂。
本发明提供一种软件定时器的优化方法及系统,所述软件定时器的优化方法及系统的发明原理为:
本发明专利设计采用两个数组来处理定时器。定时器管理链表数组A[]和定时器超时检测处理链表B[]。系统启动后运行的总运行时刻gTimerJiffies(每次等待的时间片timerTick(可设置为1tick或1s)的累加总和)。每个时刻所有定时器实例对象超时处理需要的耗时时间gAlignmentTime。
使用数组A[]进行定时器的创建,开启,停止及删除等操作管理处理。数组A[]为一个较小数组,可根据业务模块数设置数组个数,为每个需要使用定时器的业务模块生成一个定时器链表索引号,该定时器链表索引号可索引数组A[]中的链表数组元素,将一业务模块中的多个定时器实例对象以生成的定时器链表索引号添加到数组A[]中的链表数组元素中。由于将所有的定时器实例对象是按业务模块进行了划分,对定时器实例对象的操作不需要遍历所有的定时器实例对象,最坏情况下只需遍历本模块的定时器实例对象,业务模块较多时提高了定时器实例对象的操作效率。
使用数组B[]进行定时器的超时检测和超时回调处理,数组B[]为一个大数组,每个链表数组元素为一个链表,链表的索引使用系统运行的时刻进行索引,每个链表数组元素存放的都是当前时刻应该执行的定时器。
在开启定时器实例对象的时候,以业务模块为索引Modindex将定时器实例对象添加到数组A[ModIndex]中,以定时器实例对象的超时时间timeout_interval加上当前时刻gTimerJiffies的值为索引timeInedx,添加到B[timeInedx]的链表数组元素中。
初始化总运行时刻gTimerJiffies为0,每个时刻所有定时器实例对象超时处理需要的耗时时间gAlignmentTime为0,定时器任务执行一个死循环,死循环每等待一个时间片timerTick后对总运行时刻gTimerJiffies加1,接着从gTimerJiffies到gTimerJiffies+gAlignmentTime为索引依次执行这些时刻超时的定时器回调处理函数,全部执行完以后gTimerJiffies设置为gTimerJiffies+gAlignmentTime,对定时器进行补偿。计数这些定时器所有的执行的耗时时间,耗时时间大于timerTick时设置gAlignmentTime。接着执行下一次死循环。系统每个时刻只去访问处理当前时刻已超时的定时器实例对象,不需访问所有定时器对象,极大的减少的CPU的占用率,同时对定时器对象的超时回调处理进行了耗时计算,对定时器进行了时间漂移补偿,提高了定时器的定时准确度。
实施例一
本实施例提供一种软件定时器的优化方法,应用于若干个需要使用定时器的业务模块中,每一个业务模块包括多个定时器实例对象,请参阅图2,显示为软件定时器的软化方法的流程图,所述软件定时器的优化方法包括:
S1,为每一个需要使用定时器的业务模块生成定时器链表索引号,创建包括与所述业务模块数量一致的链表数组元素的第一定时器数组A[];定义总运行时间,记录为T1,即gTimerJiffies,和每个时刻所有定时器实例对象超时处理所需时间,记录为T2,即gAlignmentTime,初始化所述T1(gTimerJiffies)和所述T2(gAlignmentTime)为零。所述定时器实例对象包括记录存在于所述第一定时器数组中链表数组元素的节点的第一节点指针、记录存在于所述第二定时器数组中链表数组元素的节点的第二节点指针、定时器超时回调处理函数、及定时器超时回调处理参数。所述定时器实例对象中的第一节点指针记录所述第一定时器数组中所述链表数组元素的首地址。所述定时器实例对象中的第二节点指针记录所述第二定时器数组中链表数组元素的首地址。
S2,等待一时间片timerTick(在本实施例中,所述时间片timerTick可设置为1tick或1s)后,所述总运行时间T1(gTimerJiffies)自动加1,记录第一总运行时间T1’(gTimerJiffies)。
S3,开启所述业务模块中的定时器实例对象,根据所述定时器链表索引号将所述业务模块包括的多个定时器实例对象添加至所述第一定时器数组A[]的链表数组元素中。
S4,创建第二定时器数组B[],在所述第二定时器数组检测所述定时器实例对象的超时,记录该定时器实例对象的超时时间T3,生成由该定时器实例对象的超时时间T3与第一总运行时间T1’之和组成的索引时刻。在本实施例中,所述第一定时器数组为定时器管理链表数组,所述第二定时器数组为定时器超时检测处理链表数组。例如,在总运行时间gTimerJiffies为1,2,3,4,5,6个等待的时间片timerTick的时刻分别开启了业务模块1的定时器a、b,业务模块2的定时器c,业务模块3的定时器d、e、f,六个定时器实例对象的超时时间T3(timeout_interval)分别为3,1,1,4,2,1个timerTick,则六个定时器实例对象在第二定时器数组B[]中的索引时刻[gTimerJiffies+timeout_interval]分别为4,3,4,8,7,7,此时具体实施方式第一定时器数组A[]和第二定时器数组B[]中定时器实例对象存储示意图如图3和图4。
S5,根据所述索引时刻将与所述索引时刻相对应的定时器实例对象添加至所述第二定时器数组B[]的链表数组元素中。
S6,判断所述索引时刻是否小于等于第一总运行时间T1’(gTimerJiffies)与所有定时器实例对象超时处理所需时间T2(gAlignmentTime)之和,若是,则执行步骤S7,若否,执行步骤S10,即记录第二总运行时间T1”。
S7,判断所述第二定时器数组的链表数组元素中是否存在定时器实例对象,若是,则执行步骤S8,若否,则返回步骤S2,重新运行所述软件定时器的优化方法。
S8,若所述链表数组元素中存在定时器实例对象,则在所述第二定时器数组中循环执行所述链表数组元素的定时器实例对象的定时器超时回调处理函数,之后根据所述定时器实例对象中的第二节点指针在所述第二定时器数组中删除该定时器实例对象,同时本步骤还包括根据所述定时器实例对象中的第一节点指针在所述第一定时器数组中删除所述定时器实例对象。
S9,判断该定时器实例对象下是否还存在其他定时器实例对象,在本实施例中,所述其他定时器实例对象是指执行完超时回调处理函数后定时器实例对象下的另一定时器实例对象,若是,则执行超时回调处理函数的步骤,及返回步骤S8,若否,则执行步骤S10,即记录第二总运行时间T1”。
S11,判断第二总运行时间T1”与记录第一总运行时间T1’之差是否大于所述时间片timerTick,第二总运行时间T1”与记录第一总运行时间T1’之差为计数所有定时器实例对象的执行的耗时时间,若否,则执行步骤S12,及将所有定时器实例对象超时处理所需时间T2赋值为零,若是,则执行步骤S13,即将所有定时器实例对象超时处理所需时间T2赋值为T1”-T1’。在本实施例中,每个时刻只需访问处理当前时刻已超时的定时器实例对象,不需要方法所有的定时器实例对象,极大地减少了CPU的占用率,同时对定时器实例对象的超时回调处理进行了耗时计算,对定时器实例对象进行了时间偏移补偿,提高了定时器的定时时间的准确度。
S14,继续下一次循环,令总运行时间T1为零的所有定时器实例对象超时处理所需时间T2或为T1”-T1’的所有定时器实例对象超时处理所需时间T2以对定时器进行补偿。
本实施例所提供的软件定时器的优化方法由于此设计按照模块划分定时器实例对象,提高了定时器实例对象的操作效率。对定时器按照超时时间添加到定时器超时检测处理数组中,每个时刻只会去访问处理当前时刻已超时的定时器实例对象,不需访问所有定时器实例对象,极大的减少的CPU的占用率,同时对定时器对象的超时回调处理进行了耗时计算,对定时器进行了时间漂移补偿,提高了定时器的定时准确度。
实施例二
本实施例提供一种软件定时器的优化系统1,应用于若干个需要使用定时器的业务模块中,每一个业务模块包括多个定时器实例对象,请参阅图5,显示为软件定时器的优化系统的原理结构图,所述软件定时器的优化系统包括:第一创建模块11、管理模块12、第二创建模块13、处理模块14、第一判断模块15、第二判断模块16、第三判断模块17、第四判断模块18、及赋值模块19。
所述第一创建模块11用于为每一个需要使用定时器的业务模块生成定时器链表索引号,创建包括与所述业务模块数量一致的链表数组元素的第一定时器数组A[];定义总运行时间,记录为T1和每个时刻所有定时器实例对象超时处理所需时间,记录为T2,初始化所述T1和和所述T2为零;所述定时器实例对象包括定时器超时回调处理函数;且所述第一创建模块还用于等待一时间片后,为所述总运行时间T1自动加1,记录第一总运行时间T1’。所述定时器实例对象包括记录存在于所述第一定时器数组中链表数组元素的节点的第一节点指针、记录存在于所述第二定时器数组中链表数组元素的节点的第二节点指针、定时器超时回调处理函数、及定时器超时回调处理参数。所述定时器实例对象中的第一节点指针记录所述第一定时器数组中所述链表数组元素的首地址。所述定时器实例对象中的第二节点指针记录所述第二定时器数组中链表数组元素的首地址。
与所述第一创建模块11连接的所述管理模块12用于开启所述业务模块中的定时器实例对象,根据所述定时器链表索引号将所述业务模块包括的多个定时器实例对象添加至所述第一定时器数组的链表数组元素中。
与所述管理模块12连接第二创建模块13用于创建第二定时器数组,在所述第二定时器数组检测所述定时器实例对象的超时,记录该定时器实例对象的超时时间T3,生成由该定时器实例对象的超时时间T3与第一总运行时间T1’之和组成的索引时刻。
当所述第二定时器数组创建后,所述管理模块12还用于根据所述索引时刻将与所述索引时刻相对应的定时器实例对象添加至所述第二定时器数组的链表数组元素中。
分别与所述管理模块12和所述第二创建模块13连接的处理模块14用于在所述第二定时器数组中循环执行所述链表数组元素下的定时器实例对象的超时回调处理函数,执行完后根据所述定时器实例对象中的第二节点指针在所述第二定时器数组中删除该定时器实例对象,继续执行该定时器实例对象下的另一定时器实例对象,直至执行完毕该链表数组元素下所有定时器实例对象。在本实施例中,所述处理模块14同时还用于根据所述定时器实例对象中的第一节点指针在所述第一定时器数组中删除所述定时器实例对象。
与所述处理模块14连接的第一判断模块15用于判断所述索引时刻是否小于等于第一总运行时间T1’与所有定时器实例对象超时处理所需时间T2之和,若是,则调用所述第二判断模块16,若否,则调用所述第二创建模块13记录第二总运行时间T1”;
与所述第一判断模块15连接的所述第二判断模块16用于判断所述第二定时器数组的链表数组元素中是否存在定时器实例对象,若是,调用所述处理模块14,若否,则重新运行所述软件定时器的优化系统1。所述处理模块14用于若所述链表数组元素中存在定时器实例对象,则在所述第二定时器数组中循环执行所述链表数组元素的定时器实例对象的定时器超时回调处理函数,之后根据第二节点指针删除定时器实例对象,同时根据第一节点指针在第一定时器数组中删除定时器实例对象。
与所述第二判断模块16连接的所述第三判断模块17用于判断该定时器实例对象下是否还存在其他定时器实例对象,在本实施例中,所述其他定时器实例对象是指执行完超时回调处理函数后定时器实例对象下的另一定时器实例对象,若是,则继续调用所述处理模块14,执行超时回调处理函数的步骤,之后根据第二节点指针删除其他定时器实例对象,同时根据第一节点指针在第一定时器数组中删除其他定时器实例对象,若否,则调用所述第二创建模块13记录第二总运行时间T1”。
与所述第三判断模块17连接的所述第四判断模块18用于判断第二总运行时间T1”与记录第一总运行时间T1’之差是否大于所述时间片timerTick,若否,则调用所述赋值模块19,将所有定时器实例对象超时处理所需时间T2赋值为零,若是,也将调用所述赋值模块19,为所有定时器实例对象超时处理所需时间T2赋值为T1”-T1’。最后,所述当所有定时器实例对象超时处理所需时间T2赋值为零或为T1”-T1’时,所述赋值模块令总运行时间T1为零的所有定时器实例对象超时处理所需时间T2或为T1”-T1’的所有定时器实例对象超时处理所需时间T2以对定时器进行补偿。
本发明所述的软件定时器的优化方法及系统由于此设计按照模块划分定时器实例对象,提高了定时器实例对象的操作效率。对定时器按照超时时间添加到定时器超时检测处理数组中,每个时刻只会去访问处理当前时刻已超时的定时器实例对象,不需访问所有定时器实例对象,极大的减少的CPU的占用率,同时对定时器对象的超时回调处理进行了耗时计算,对定时器进行了时间漂移补偿,提高了定时器的定时准确度。
所以,本发明有效克服了现有技术中的种种缺点而具高度产业利用价值。
上述实施例仅例示性说明本发明的原理及其功效,而非用于限制本发明。任何熟悉此技术的人士皆可在不违背本发明的精神及范畴下,对上述实施例进行修饰或改变。因此,举凡所属技术领域中具有通常知识者在未脱离本发明所揭示的精神与技术思想下所完成的一切等效修饰或改变,仍应由本发明的权利要求所涵盖。

Claims (8)

1.一种软件定时器的优化方法,应用于若干个需要使用定时器的业务模块中,每一个业务模块包括多个定时器实例对象,其特征在于,包括:
步骤一,为每一个需要使用定时器的业务模块生成定时器链表索引号,创建包括与所述业务模块数量一致的链表数组元素的第一定时器数组;定义总运行时间,记录为T1和每个时刻所有定时器实例对象超时处理所需时间,记录为T2,初始化所述T1和所述T2为零;所述定时器实例对象包括定时器超时回调处理函数;
步骤二,等待一时间片后,所述总运行时间T1自动加1,记录第一总运行时间T1’;
步骤三,开启所述业务模块中的定时器实例对象,根据所述定时器链表索引号将所述业务模块包括的多个定时器实例对象添加至所述第一定时器数组的链表数组元素中;
步骤四,创建第二定时器数组,在所述第二定时器数组检测所述定时器实例对象的超时,记录该定时器实例对象的超时时间T3,生成由该定时器实例对象的超时时间T3与第一总运行时间T1’之和组成的索引时刻;
步骤五,根据所述索引时刻将与所述索引时刻相对应的定时器实例对象添加至所述第二定时器数组的链表数组元素中;
步骤六,在所述第二定时器数组中循环执行所述链表数组元素下的定时器实例对象的超时回调处理函数,执行完后删除该定时器实例对象,继续执行该定时器实例对象下的其他定时器实例对象,直至执行完毕该链表数组元素下所有定时器实例对象,继续下一次循环;
所述软件定时器的优化方法还包括:
判断所述索引时刻是否小于等于第一总运行时间T1’与所有定时器实例对象超时处理所需时间T2之和,若是,则执行下一步骤,若否,则记录第二总运行时间T1”;
判断所述第二定时器数组的链表数组元素中是否存在定时器实例对象,若是,则执行下一步骤,若否,则返回步骤二,重新运行所述软件定时器的优化方法;
若所述链表数组元素中存在定时器实例对象,则在所述第二定时器数组中循环执行所述链表数组元素的定时器实例对象的定时器超时回调处理函数,之后删除该定时器实例对象。
2.根据权利要求1所述的软件定时器的优化方法,其特征在于:所述软件定时器的优化方法还包括:
判断该定时器实例对象下是否还存在其他定时器实例对象,若是,则执行超时回调处理函数的步骤,若否,则记录第二总运行时间T1”;
判断第二总运行时间T1”与记录第一总运行时间T1’之差是否大于所述时间片,若否,则表示为所有定时器实例对象超时处理所需时间T2赋值为零,若是,则表示为所有定时器实例对象超时处理所需时间T2赋值为为T1”-T1’,继续下一次循环。
3.根据权利要求1所述的软件定时器的优化方法,其特征在于:所述定时器实例对象还包括记录存在于所述第一定时器数组中链表数组元素的节点的第一节点指针、记录存在于所述第二定时器数组中链表数组元素的节点的第二节点指针、及定时器超时回调处理参数。
4.根据权利要求3所述的软件定时器的优化方法,其特征在于:所述定时器实例对象中的第一节点指针记录所述第一定时器数组中所述链表数组元素的首地址,所述定时器实例对象中的第二节点指针记录所述第二定时器数组中链表数组元素的首地址。
5.根据权利要求4所述的软件定时器的优化方法,其特征在于:所述步骤六还包括根据所述定时器实例对象中的第一节点指针在所述第一定时器数组中删除所述定时器实例对象。
6.根据权利要求1所述的软件定时器的优化方法,其特征在于:所述第一定时器数组为定时器管理链表数组,所述第二定时器数组为定时器超时检测处理链表数组。
7.一种软件定时器的优化系统,应用于若干个需要使用定时器的业务模块中,每一个业务模块包括多个定时器实例对象,其特征在于,包括:
第一创建模块,用于为每一个需要使用定时器的业务模块生成定时器链表索引号,创建包括与所述业务模块数量一致的链表数组元素的第一定时器数组;定义总运行时间,记录为T1和每个时刻所有定时器实例对象超时处理所需时间,记录为T2,初始化所述T1和和所述T2为零;所述定时器实例对象包括定时器超时回调处理函数;且所述第一创建模块还用于等待一时间片后,为所述总运行时间T1自动加1,记录第一总运行时间T1’;
管理模块,用于开启所述业务模块中的定时器实例对象,根据所述定时器链表索引号将所述业务模块包括的多个定时器实例对象添加至所述第一定时器数组的链表数组元素中;
第二创建模块,用于创建第二定时器数组,在所述第二定时器数组检测所述定时器实例对象的超时,记录该定时器实例对象的超时时间T3,生成由该定时器实例对象的超时时间T3与第一总运行时间T1’之和组成的索引时刻;
所述管理模块还用于根据所述索引时刻将与所述索引时刻相对应的定时器实例对象添加至所述第二定时器数组的链表数组元素中;
处理模块,用于在所述第二定时器数组中循环执行所述链表数组元素下的定时器实例对象的超时回调处理函数,执行完后删除该定时器实例对象,继续执行该定时器实例对象下的其他定时器实例对象,直至执行完毕该链表数组元素下所有定时器实例对象;
所述软件定时器的优化系统还包括:第一判断模块和第二判断模块;
其中,所述第一判断模块用于判断所述索引时刻是否小于等于第一总运行时间T1’与所有定时器实例对象超时处理所需时间T2之和,若是,则调用所述第二判断模块,若否,则调用所述第二创建模块记录第二总运行时间T1”;
所述第二判断模块用于判断所述第二定时器数组的链表数组元素中是否存在定时器实例对象,若是,调用所述处理模块,若否,则重新运行所述软件定时器的优化系统;
所述处理模块用于若所述链表数组元素中存在其他定时器实例对象,则在所述第二定时器数组中循环执行所述链表数组元素的定时器实例对象的定时器超时回调处理函数,之后删除该定时器实例对象。
8.根据权利要求7所述的软件定时器的优化系统,其特征在于:所述软件定时器的优化系统还包括:第三判断模块和第四判断模块;
其中,所述第三判断模块用于判断该定时器实例对象下是否还存在其他定时器实例对象,若是,则继续调用所述处理模块,执行超时回调处理函数的步骤,若否,则调用所述第二创建模块记录第二总运行时间T1”;
所述第四判断模块用于判断第二总运行时间T1”与记录第一总运行时间T1’之差是否大于所述时间片,若否,则表示为所有定时器实例对象超时处理所需时间T2赋值为零,若是,则表示为所有定时器实例对象超时处理所需时间T2赋值为T1”-T1’,继续下一次循环。
CN201410309635.XA 2014-07-01 2014-07-01 一种软件定时器的优化方法及系统 Active CN104035786B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201410309635.XA CN104035786B (zh) 2014-07-01 2014-07-01 一种软件定时器的优化方法及系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201410309635.XA CN104035786B (zh) 2014-07-01 2014-07-01 一种软件定时器的优化方法及系统

Publications (2)

Publication Number Publication Date
CN104035786A CN104035786A (zh) 2014-09-10
CN104035786B true CN104035786B (zh) 2017-11-24

Family

ID=51466561

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201410309635.XA Active CN104035786B (zh) 2014-07-01 2014-07-01 一种软件定时器的优化方法及系统

Country Status (1)

Country Link
CN (1) CN104035786B (zh)

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104597820B (zh) * 2015-02-11 2017-07-28 四川天邑康和通信股份有限公司 一种扩展单片机硬件定时器的方法
CN106126326A (zh) * 2016-06-23 2016-11-16 东软集团股份有限公司 定时任务管理方法和装置
CN106383694A (zh) * 2016-09-09 2017-02-08 合普新能源科技有限公司 一种虚拟定时器定时方法
CN106533845A (zh) * 2016-12-27 2017-03-22 海尔优家智能科技(北京)有限公司 一种长连接状态监控方法和装置
CN107870812B (zh) * 2017-11-17 2021-06-15 南京国电南自轨道交通工程有限公司 一种基于单线程并发多定时器应用管理方法
EP3550431B1 (en) * 2018-01-16 2021-12-08 Shenzhen Goodix Technology Co., Ltd. Timer implementation method and device
CN108763109B (zh) * 2018-06-13 2022-04-26 成都心吉康科技有限公司 数据存储方法、装置及其应用
CN111556087B (zh) * 2020-03-06 2023-02-28 远景智能国际私人投资有限公司 数据发送方法、装置、设备及可读存储介质
CN115934000B (zh) * 2023-03-07 2023-06-09 苏州浪潮智能科技有限公司 一种存储系统的定时方法及相关装置

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101853047A (zh) * 2010-05-18 2010-10-06 瑞斯康达科技发展股份有限公司 一种定时器实现方法及装置
CN102270156A (zh) * 2011-05-30 2011-12-07 北京华源格林科技有限公司 一种实时嵌入式系统定时器管理方法
CN102761541A (zh) * 2012-05-31 2012-10-31 汉柏科技有限公司 定时器处理方法及系统
CN103019805A (zh) * 2011-09-20 2013-04-03 佳都新太科技股份有限公司 一种多线程环境下定时器的设置方法

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101853047A (zh) * 2010-05-18 2010-10-06 瑞斯康达科技发展股份有限公司 一种定时器实现方法及装置
CN102270156A (zh) * 2011-05-30 2011-12-07 北京华源格林科技有限公司 一种实时嵌入式系统定时器管理方法
CN103019805A (zh) * 2011-09-20 2013-04-03 佳都新太科技股份有限公司 一种多线程环境下定时器的设置方法
CN102761541A (zh) * 2012-05-31 2012-10-31 汉柏科技有限公司 定时器处理方法及系统

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
"Linux平台下增强型定时器服务的研究";晋磊 等;《微型电脑应用》;20051120;第21卷(第11期);41-43 *
"基于多线程和缓存机制的定时器管理算法研究";陈志龙 等;《2014第二届中国指挥控制大会论文集(上)》;20140803;603-607 *

Also Published As

Publication number Publication date
CN104035786A (zh) 2014-09-10

Similar Documents

Publication Publication Date Title
CN104035786B (zh) 一种软件定时器的优化方法及系统
CN102214139B (zh) 一种面向分布式系统的自动化测试的执行控制与调度方法
Fanti et al. Event-based feedback control for deadlock avoidance in flexible production systems
CN108388615B (zh) 一种数据交换方法、系统以及电子设备
CN103885881B (zh) 一种基于VxWorks系统多任务机制的高实时并发测试方法
US8087022B2 (en) Prevention of deadlock in a distributed computing environment
WO2011137672A1 (zh) 基于数据库的任务执行方法及装置
CN108845954A (zh) 压力测试方法、系统及存储介质
CN107526645A (zh) 一种通信优化方法及系统
CN108156181A (zh) 一种基于协程异步io的漏洞探测方法及其漏洞扫描系统
CN107273195A (zh) 一种大数据的批处理方法、装置及计算机系统
CN107491346A (zh) 一种应用的任务处理方法、装置及系统
US20060225042A1 (en) Virtual threads in business process programs
CN106886450A (zh) 任务调度方法和系统
CN110347952A (zh) 一种打开直播间页面的方法、装置及计算机设备
CN102457578A (zh) 一种基于事件机制的分布式网络监控方法
CN106502770A (zh) 一种基于有限状态机的hmi状态迁移方法
US7783933B2 (en) Identifying failure in a tree network of a parallel computer
CN105939345A (zh) 协议表项定时器的管理方法及装置
Marynowski et al. Testing mapreduce-based systems
WO2022033672A1 (en) Apparatus and method for injecting a fault into a distributed system
CN116308343A (zh) 智能合约交易并行执行方法及系统
CN106506282A (zh) 一种提高云平台监控性能及规模的监控方法
CN105447012B (zh) 一种用于数据库的写入互斥方法及装置
CN113722141B (zh) 数据任务的延迟原因确定方法、装置、电子设备及介质

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
EXSB Decision made by sipo to initiate substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
TR01 Transfer of patent right
TR01 Transfer of patent right

Effective date of registration: 20201208

Address after: 313028 Industrial Park, balidian Town, Huzhou City, Zhejiang Province

Patentee after: HUZHOU FENGYUAN AGRICULTURAL EQUIPMENT MANUFACTURE Co.,Ltd.

Address before: 201616 Shanghai city Songjiang District Guangfulin road 4855 Lane 20, No. 90

Patentee before: Phicomm (Shanghai) Co.,Ltd.

PE01 Entry into force of the registration of the contract for pledge of patent right

Denomination of invention: An optimization method and system of software timer

Effective date of registration: 20210630

Granted publication date: 20171124

Pledgee: Zhejiang Tailong Commercial Bank Co.,Ltd. Huzhou Branch

Pledgor: HUZHOU FENGYUAN AGRICULTURAL EQUIPMENT MANUFACTURE Co.,Ltd.

Registration number: Y2021330000755

PE01 Entry into force of the registration of the contract for pledge of patent right
PC01 Cancellation of the registration of the contract for pledge of patent right

Date of cancellation: 20230811

Granted publication date: 20171124

Pledgee: Zhejiang Tailong Commercial Bank Co.,Ltd. Huzhou Branch

Pledgor: HUZHOU FENGYUAN AGRICULTURAL EQUIPMENT MANUFACTURE Co.,Ltd.

Registration number: Y2021330000755

PC01 Cancellation of the registration of the contract for pledge of patent right
TR01 Transfer of patent right

Effective date of registration: 20240228

Address after: 710075 Building 5-150, Jinghe Zhigu, Chongwen Town, Jinghe New City, Xixian New District, Xi'an City, Shaanxi Province, China

Patentee after: Shaanxi Green Water Technology Co.,Ltd.

Country or region after: China

Address before: 313028 Industrial Park, balidian Town, Huzhou City, Zhejiang Province

Patentee before: HUZHOU FENGYUAN AGRICULTURAL EQUIPMENT MANUFACTURE Co.,Ltd.

Country or region before: China

TR01 Transfer of patent right