《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 其他 > Linux教學——linux編程之經典多級時間輪定時器(C語言版)

Linux教學——linux編程之經典多級時間輪定時器(C語言版)

2022-11-07
來源:電子技術應用專欄作家 一口Linux

  一. 多級時間輪實現框架

微信截圖_20221107164603.png

  上圖是5個時間輪級聯的效果圖。中間的大輪是工作輪,只有在它上的任務才會被執行;其他輪上的任務時間到后遷移到下一級輪上,他們最終都會遷移到工作輪上而被調度執行。

  多級時間輪的原理也容易理解:就拿時鐘做說明,秒針轉動一圈分針轉動一格;分針轉動一圈時針轉動一格;同理時間輪也是如此:當低級輪轉動一圈時,高一級輪轉動一格,同時會將高一級輪上的任務重新分配到低級輪上。從而實現了多級輪級聯的效果。

  1.1 多級時間輪對象

  微信截圖_20221107164808.png

  多級時間輪應該至少包括以下內容:

  每一級時間輪對象

  輪子上指針的位置 關于輪子上指針的位置有一個比較巧妙的辦法:那就是位運算。比如定義一個無符號整型的數:

  微信截圖_20221107164832.png

  通過獲取當前的系統時間便可以通過位操作轉換為時間輪上的時間,通過與實際時間輪上的時間作比較,從而確定時間輪要前進調度的時間,進而操作對應時間輪槽位對應的任務。

  為什么至少需要這兩個成員呢?

  定義多級時間輪,首先需要明確的便是級聯的層數,也就是說需要確定有幾個時間輪。

  輪子上指針位置,就是當前時間輪運行到的位置,它與真實時間的差便是后續時間輪需要調度執行,它們的差值是時間輪運作起來的驅動力。

  多級時間輪對象的定義

 微信截圖_20221107164856.png

  1.2 時間輪對象

  微信截圖_20221107164914.png

  我們知道每一個輪子實際上都是一個哈希表,上面我們只是實例化了五個輪子的對象,但是五個輪子具體包含什么,有幾個槽位等等沒有明確(即struct tvec和struct tvec_root)。

微信截圖_20221107164932.png

  此外,每一個時間輪都是哈希表,因此它的類型應該至少包含兩個指針域來實現雙向鏈表的功能。這里我們為了方便使用通用的struct list_head的雙向鏈表結構。

  1.3 定時任務對象

  微信截圖_20221107165005.png

  定時器的主要工作是為了在未來的特定時間完成某項任務,而這個任務經常包含以下內容:

  任務的處理邏輯(回調函數)

  任務的參數

  雙向鏈表節點

  到時時間

  定時任務對象的定義

 微信截圖_20221107165026.png

  在時間輪上的效果圖:

  微信截圖_20221107165050.png

  1.4 雙向鏈表

  在時間輪上我們采用雙向鏈表的數據類型。采用雙向鏈表的除了操作上比單鏈表復雜,多占一個指針域外沒有其他不可接收的問題。而多占一個指針域在今天大內存的時代明顯不是什么問題。至于雙向鏈表操作的復雜性,我們可以通過使用通用的struct list結構來解決,因為雙向鏈表有眾多的標準操作函數,我們可以通過直接引用list.h頭文件來使用他們提供的接口。

  struct list可以說是一個萬能的雙向鏈表操作框架,我們只需要在自定義的結構中定義一個struct list對象即可使用它的標準操作接口。同時它還提供了一個類似container_of的接口,在應用層一般叫做list_entry,因此我們可以很方便的通過struct list成員找到自定義的結構體的起始地址。

  關于應用層的log.h, 我將在下面的代碼中附上該文件。如果需要內核層的實現,可以直接從linux源碼中獲取。

  1.5 聯結方式

  多級時間輪效果圖:

  微信截圖_20221107165120.png

  二. 多級時間輪C語言實現

  2.1 雙向鏈表頭文件: list.h

  提到雙向鏈表,很多的源碼工程中都會實現一系列的統一的雙向鏈表操作函數。它們為雙向鏈表封裝了統計的接口,使用者只需要在自定義的結構中添加一個struct list_head結構,然后調用它們提供的接口,便可以完成雙向鏈表的所有操作。這些操作一般都在list.h的頭文件中實現。Linux源碼中也有實現(內核態的實現)。他們實現的方式基本完全一樣,只是實現的接口數量和功能上稍有差別。可以說這個list.h文件是學習操作雙向鏈表的不二選擇,它幾乎實現了所有的操作:增、刪、改、查、遍歷、替換、清空等等。這里我拼湊了一個源碼中的log.h函數,終于湊夠了多級時間輪中使用到的接口。

微信截圖_20221107165224.png

微信截圖_20221107165254.png

微信截圖_20221107165330.png

微信截圖_20221107165352.png

微信截圖_20221107165433.png

  這里面一般會用到一個重要實現:container_of, 它的原理這里不敘述

  2.2 調試信息頭文件: log.h

  這個頭文件實際上不是必須的,我只是用它來添加調試信息(代碼中的errlog(), log()都是log.h中的宏函數)。它的效果是給打印的信息加上顏色,效果如下:

  微信截圖_20221107165500.png

  log.h的代碼如下:

  微信截圖_20221107165530.png

  2.3 時間輪代碼: timewheel.c

微信截圖_20221107165659.png

微信截圖_20221107165725.png微信截圖_20221107165755.png微信截圖_20221107165839.png微信截圖_20221107165911.png微信截圖_20221107165944.png

微信截圖_20221107170011.png

微信截圖_20221107170038.png微信截圖_20221107170206.png

微信截圖_20221107170332.png

微信截圖_20221107170350.png

  2.4 編譯運行

  微信截圖_20221107170433.png

  從結果可以看出:如果添加的定時任務是比較耗時的操作,那么后續的任務也會被阻塞,可能一直到超時,甚至一直阻塞下去,這個取決于當前任務是否耗時。

  這個理論上是絕不能接受的:一個任務不應該也不能去影響其他的任務吧。但是目前沒有對此問題進行改進和完善,以后有機會再繼續完善吧。


  更多信息可以來這里獲取==>>電子技術應用-AET<<

微信圖片_20210517164139.jpg

微信圖片_20220701092006.jpg

電子技術應用專欄作家  一口Linux

原文鏈接:https://mp.weixin.qq.com/s/pmHS5IlW1gfQSyeIYu3IGQ

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
在线亚洲观看| 一本色道久久| 亚洲裸体在线观看| 悠悠资源网久久精品| 国产区二精品视| 国产欧美一区二区精品性色| 国产精品初高中精品久久| 欧美日韩1区| 欧美日韩一区在线观看| 欧美女同视频| 欧美视频二区36p| 国产精品久久久久久久一区探花| 欧美精品色综合| 欧美日韩在线播放三区四区| 欧美视频你懂的| 国产精品久久久久永久免费观看| 国产精品jizz在线观看美国| 国产精品久久77777| 国产精品裸体一区二区三区| 你懂的国产精品| 一本大道久久精品懂色aⅴ| 亚洲精品在线免费| 99re6这里只有精品| 一区二区三区国产| 亚洲永久在线| 亚洲无线观看| 午夜精品短视频| 性8sex亚洲区入口| 久久精品成人一区二区三区| 久久久久久成人| 欧美成人免费一级人片100| 欧美激情精品| 国产精品sm| 国产日韩成人精品| 伊人久久大香线蕉综合热线| 亚洲区在线播放| 宅男在线国产精品| 欧美亚洲免费电影| 亚洲欧洲三级| 亚洲视频欧美视频| 欧美一区二区在线免费播放| 久久麻豆一区二区| 欧美精品免费看| 国产精品午夜在线观看| 黄色在线一区| 日韩网站在线观看| 香蕉久久夜色精品国产| 亚洲人成啪啪网站| 亚洲自拍偷拍福利| 久久久久久综合| 欧美日韩高清在线| 国产视频在线一区二区| 亚洲电影网站| 亚洲一区二区三区四区五区黄 | 亚洲欧美一区二区在线观看| 久久久国产视频91| 欧美精品日韩www.p站| 国产欧美日韩一区| 亚洲毛片视频| 欧美在线1区| 亚洲性人人天天夜夜摸| 久久一本综合频道| 欧美四级电影网站| 在线日韩av片| 午夜精品久久久久久久久| 亚洲精品永久免费| 久久九九精品99国产精品| 欧美日韩精品不卡| 激情偷拍久久| 亚洲综合色在线| 夜夜嗨av一区二区三区网站四季av| 久久成人人人人精品欧| 欧美日本亚洲韩国国产| 国产一区二区观看| 中文精品视频| 亚洲看片一区| 久久深夜福利| 国产精品久久77777| 亚洲国产精品一区二区尤物区| 亚洲欧美卡通另类91av| 一本大道av伊人久久综合| 久久天天狠狠| 国产色产综合产在线视频| 99在线观看免费视频精品观看| 久久精品国产视频| 欧美一区二区私人影院日本| 欧美日韩理论| 亚洲黄色av| 久久精品一区二区三区四区| 欧美亚洲视频在线看网址| 欧美日韩在线播放| 亚洲破处大片| 亚洲欧洲免费视频| 久久一区二区精品| 国内成+人亚洲+欧美+综合在线| 亚洲无限乱码一二三四麻| 99天天综合性| 欧美高清视频在线| 影音先锋亚洲视频| 久久精品国内一区二区三区| 欧美一区二区精品| 国产精品亚洲人在线观看| 99国产精品久久久久久久| 99国产精品一区| 欧美国产综合| 伊人成人在线| 久久激情视频| 老司机午夜免费精品视频| 国产一区二区三区奇米久涩| 亚洲欧美影音先锋| 欧美一区二区三区免费在线看| 国产精品久久久久久一区二区三区| 日韩视频一区二区三区在线播放免费观看 | 午夜精品成人在线| 欧美夜福利tv在线| 国产精品日韩一区| 亚洲欧美激情一区| 欧美在线一二三| 国产亚洲成人一区| 欧美亚洲视频在线观看| 久久久91精品| 国内精品久久久久久久影视麻豆| 欧美在线观看日本一区| 久久久久看片| 在线观看日韩av| 亚洲精品影院在线观看| 欧美激情一区二区三区全黄| 亚洲精品国产精品久久清纯直播| 亚洲精选久久| 欧美天天在线| 亚洲图片你懂的| 欧美主播一区二区三区| 国精品一区二区三区| 亚洲国产99精品国自产| 欧美精品二区三区四区免费看视频| 亚洲精品国产精品久久清纯直播| 亚洲手机视频| 国产精品欧美日韩一区二区| 午夜在线一区| 免费观看一区| 日韩性生活视频| 欧美一区二区三区在线播放| 国产一区二区三区久久久久久久久 | 亚洲一区久久久| 久久九九精品| 亚洲第一区中文99精品| 亚洲精品专区| 国产精品高清一区二区三区| 亚洲欧洲av一区二区| 久久伊人一区二区| 亚洲乱码视频| 欧美一区二区在线播放| 一区精品在线播放| 夜夜爽夜夜爽精品视频| 国产精品永久免费视频| 亚洲国产精品一区二区www在线 | 激情综合自拍| 中文精品视频一区二区在线观看| 国产精品欧美久久| 亚洲风情亚aⅴ在线发布| 欧美巨乳在线| 亚洲综合国产| 久久久青草婷婷精品综合日韩| 亚洲国产一区二区a毛片| 亚洲欧美日韩在线不卡| 极品尤物av久久免费看| 亚洲婷婷免费| 狠狠色狠狠色综合日日tαg| 一区二区日韩伦理片| 国产亚洲精品美女| 99国产精品99久久久久久| 国产乱码精品一区二区三区忘忧草 | 午夜精品国产| 欧美激情综合在线| 午夜在线不卡| 欧美日韩一二区| 久久精品国产亚洲aⅴ| 欧美视频在线观看视频极品| 久久电影一区| 国产精品久久一区主播| 亚洲欧洲精品天堂一级| 国产精品网红福利| 亚洲精品综合久久中文字幕| 国产欧美日韩一区二区三区| 一区二区高清在线| 在线播放亚洲| 欧美在线看片| av成人免费在线| 欧美jizz19性欧美| 欧美一区二区播放| 欧美性jizz18性欧美| 亚洲欧洲在线一区| 国产亚洲毛片在线| 亚洲欧美亚洲| 日韩网站在线| 欧美电影免费| 亚洲福利视频在线| 国产精品在线看| 亚洲一区二区三区在线看 | 欧美在线观看视频在线|