2.3 時(shí)間輪代碼: timewheel.c
/*
*毫秒定時(shí)器 采用多級時(shí)間輪方式 借鑒linux內(nèi)核中的實(shí)現(xiàn)
*支持的范圍為1 ~ 2^32 毫秒(大約有49天)
*若設(shè)置的定時(shí)器超過最大值 則按最大值設(shè)置定時(shí)器
**/
#include
#include
#include
#include
#include
#include
#include "list.h"
#include "log.h"
#define TVN_BITS 6
#define TVR_BITS 8
#define TVN_SIZE (1<
2.4 編譯運(yùn)行
peng@ubuntu:/mnt/hgfs/timer/4. timerwheel/2. 多級時(shí)間輪$ ls
a.out list.h log.h mutiTimeWheel.c
toney@ubantu:/mnt/hgfs/timer錄/4. timerwheel/2. 多級時(shí)間輪$ gcc mutiTimeWheel.c -lpthread
toney@ubantu:/mnt/hgfs/timer/4. timerwheel/2. 多級時(shí)間輪$ ./a.out
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
[#DEBUG: Toeny Sun: mytimer:370]:100
從結(jié)果可以看出:如果添加的定時(shí)任務(wù)是比較耗時(shí)的操作,那么后續(xù)的任務(wù)也會(huì)被阻塞,可能一直到超時(shí),甚至一直阻塞下去,這個(gè)取決于當(dāng)前任務(wù)是否耗時(shí)。
這個(gè)理論上是絕不能接受的:一個(gè)任務(wù)不應(yīng)該也不能去影響其他的任務(wù)吧。但是目前沒有對此問題進(jìn)行改進(jìn)和完善,以后有機(jī)會(huì)再繼續(xù)完善吧。
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報(bào)投訴
-
Linux
+關(guān)注
關(guān)注
87文章
11352瀏覽量
210534 -
C語言
+關(guān)注
關(guān)注
180文章
7615瀏覽量
137874 -
定時(shí)器
+關(guān)注
關(guān)注
23文章
3256瀏覽量
115463
發(fā)布評論請先 登錄
相關(guān)推薦
Linux編程之經(jīng)典多級時(shí)間輪定時(shí)器(C語言版)
上圖是5個(gè)時(shí)間輪級聯(lián)的效果圖。中間的大輪是工作輪,只有在它上的任務(wù)才會(huì)被執(zhí)行;其他輪上的任務(wù)時(shí)間到后遷移到下一級輪上,他們最終都會(huì)遷移到工作
發(fā)表于 11-08 14:06
?897次閱讀
時(shí)間管理和定時(shí)器編程基本知識匯總
Linux系統(tǒng)編程第08期:時(shí)間管理和定時(shí)器編程 6年嵌入式開發(fā)經(jīng)驗(yàn),在多家...
發(fā)表于 12-23 08:32
Linux下實(shí)時(shí)定時(shí)器的實(shí)現(xiàn)及應(yīng)用
在嵌入式平臺的開發(fā)過程中,由于控制硬件的要求,常常需要提供精度在μs級的定時(shí)器;而linux內(nèi)核由于采用了分時(shí)系統(tǒng),一般不提供這種級別的定時(shí)器。筆者在開發(fā)高端PDA 的過程
發(fā)表于 04-16 09:19
?36次下載
CHMOS可編程時(shí)間間隔定時(shí)器芯片82C54
82C54是專為Intel系列微處理機(jī)而設(shè)計(jì)的一種可編程時(shí)間間隔定時(shí)器/計(jì)數(shù)器,它是一種通用芯片,在系統(tǒng)軟件中可以把多級
發(fā)表于 06-12 22:13
?84次下載
Linux下一種高性能定時(shí)器池的實(shí)現(xiàn)
提出Linux用戶空間下的一種高性能定時(shí)器池的實(shí)現(xiàn)方法。主要基于時(shí)間輪、紅黑樹及Linux內(nèi)核提
發(fā)表于 09-25 14:57
?25次下載
可編程控制器實(shí)驗(yàn)教程之定時(shí)器指令實(shí)驗(yàn)
可編程控制器實(shí)驗(yàn)教程之定時(shí)器指令實(shí)驗(yàn),很好的學(xué)習(xí)資料。
發(fā)表于 04-19 13:45
?0次下載
LINUX系統(tǒng)教程之如何在Linux系統(tǒng)下進(jìn)行編程
本文檔的主要內(nèi)容詳細(xì)介紹的是LINUX系統(tǒng)教程之如何在Linux系統(tǒng)下進(jìn)行編程主要內(nèi)容包括了:程序開發(fā)過程 ,
發(fā)表于 12-18 19:09
?9次下載
單片機(jī)教程之定時(shí)器和計(jì)數(shù)器原理及應(yīng)用
本文檔的主要內(nèi)容詳細(xì)介紹的是單片機(jī)教程之定時(shí)器和計(jì)數(shù)器原理及應(yīng)用主要內(nèi)容包括了:定時(shí)器、計(jì)數(shù)器原理,Mega8
發(fā)表于 01-14 17:20
?4次下載
Linux時(shí)間子系統(tǒng)中的高精度定時(shí)器(HRTIMER)的原理和實(shí)現(xiàn)
雖然大部分時(shí)間里,時(shí)間輪可以實(shí)現(xiàn)O(1)時(shí)間復(fù)雜度,但是當(dāng)有進(jìn)位發(fā)生時(shí),不可預(yù)測的O(N)定時(shí)器級聯(lián)遷移
發(fā)表于 05-10 14:11
?7753次閱讀
定時(shí)器開關(guān)怎么設(shè)置時(shí)間
定時(shí)器開關(guān):又稱定時(shí)器、定時(shí)開關(guān)、時(shí)間定時(shí)器開關(guān)等,是一種控制用電器定時(shí)自動(dòng)開啟、關(guān)閉的電氣裝置
Linux內(nèi)核定時(shí)器
在Linux內(nèi)核中,也可以通過定時(shí)器來完成定時(shí)功能。但和單片機(jī)不同的是,Linux內(nèi)核定時(shí)器是一種基于未來
時(shí)間定時(shí)器開關(guān)怎樣接線?
時(shí)間定時(shí)器:又稱時(shí)間定時(shí)器開關(guān)、定時(shí)器、定時(shí)控制器等
Linux 編程之經(jīng)典多級時(shí)間輪定時(shí)器(上)
多級時(shí)間輪的原理也容易理解:就拿時(shí)鐘做說明,秒針轉(zhuǎn)動(dòng)一圈分針轉(zhuǎn)動(dòng)一格;分針轉(zhuǎn)動(dòng)一圈時(shí)針轉(zhuǎn)動(dòng)一格;同理時(shí)間輪也是如此:當(dāng)?shù)图壿嗈D(zhuǎn)動(dòng)一圈時(shí),高一
三菱PLC編程實(shí)現(xiàn)讀出時(shí)間定時(shí)器
的功能,而定時(shí)器是實(shí)現(xiàn)時(shí)間控制的關(guān)鍵組件。本文將詳細(xì)介紹如何使用三菱PLC編程實(shí)現(xiàn)讀出時(shí)間定時(shí)器。 1.
評論