色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

一文讀懂定時器實現(xiàn)技術(shù)

jf_78858299 ? 來源:架構(gòu)之美 ? 作者: 孫玄 架構(gòu)之美 ? 2023-04-21 14:36 ? 次閱讀

1. 定時器介紹

程序里的定時器主要實現(xiàn)的功能是在未來的某個時間點執(zhí)行相應(yīng)的邏輯。在定時器模型中,一般有如下幾個定義。

interval:間隔時間,即定時器需要在interval時間后執(zhí)行

StartTimer:添加一個定時器任務(wù)

StopTimer:結(jié)束一個定時器任務(wù)

PerTickBookkeeping: 檢查定時器系統(tǒng)中,是否有定時器實例已經(jīng)到期,相當于定義了最小時間粒度。

常見的實現(xiàn)方法有如下幾種:

鏈表

排序鏈表

最小堆

時間輪

接下來我們一起看下這些方法的具體實現(xiàn)原理。

2. 定時器實現(xiàn)方法

2.1 鏈表實現(xiàn)

鏈表的實現(xiàn)方法比較粗糙。鏈表用于存儲所有的定時器,每個定時器都含有interval 和 elapse 兩個時間參數(shù),elapse表示當前被tickTimer了多少次。當elapse 和interval相等時,表示定時器到期。

在此方案中,添加定時器就是在鏈表的末尾新增一個節(jié)點,時間復雜度是 O(1)。

如果想要刪除一個定時器的話,我們需要遍歷鏈表找到對應(yīng)的定時器,時間復雜度是O(n)。

此方案下,每隔elapse時間,系統(tǒng)調(diào)用信號進行超時檢查,即PerTickBookkeeping。每次PerTickBookkeeping需要對鏈表所有定時器進行 elapse++,因此可以看出PerTickBookkeeping的時間復雜度是O(N)。

可以看出此方案過于粗暴,所以使用場景極少。

2.2 排序雙向鏈表實現(xiàn)

排序雙向鏈表是在鏈表實現(xiàn)上的優(yōu)化。優(yōu)化思路是降低時間復雜度。

首先,每次PerTickBookkeeping需要自增所有定時器的elapse變量,如果我們將interval變?yōu)榻^對時間,那么我們只需要比較當前時間和interval時間是否相等,減少了對每個定時器的操作。

如果不需要對每個定時器進行操作,我們將定時器進行排序,那么每次PerTickBookkeeping都只需要判斷第一個定時器,時間復雜度為O(1)。

相應(yīng)的,為了維持鏈表順序,每次新增定時器需要進行鏈表排序時間復雜度為 O(N)。

每次刪除定時器時,由于會持有自己節(jié)點的引用,所以不需要查找其在鏈表中所在的位置,所以時間復雜度為O(1),雙向鏈表的好處。

圖片

圖1 雙向鏈表實現(xiàn)示意圖

2.3 時間輪實現(xiàn)

時間輪的數(shù)據(jù)結(jié)構(gòu)是數(shù)組 + 鏈表。

他的時間輪為數(shù)組,新增和刪除一個任務(wù),時間復雜度都是O(1)。

PerTickBookkeeping每次轉(zhuǎn)動一格,時間復雜度也是O(1)。

2.4 最小堆實現(xiàn)

最小堆是堆的一種, (堆是一種二叉樹), 指的是堆中任何一個父節(jié)點都小于子節(jié)點, 子節(jié)點順序不作要求。

二叉排序樹(BST)指的是: 左子樹節(jié)點小于父節(jié)點, 右子樹節(jié)點大于父節(jié)點, 對所有節(jié)點適用

圖片

圖3 最小堆

樹的基本操作是插入節(jié)點和刪除節(jié)點。對最小堆而言,為了將一個元素X插入最小堆,我們可以在樹的下一個空閑位置創(chuàng)建一個空穴。如果X可以放在空穴中而不被破壞堆的序,則插入完成。否則就執(zhí)行上濾操作,即交換空穴和它的父節(jié)點上的元素。不斷執(zhí)行上述過程,直到X可以被放入空穴,則插入操作完成。

因此我們可以知道最小堆的插入時間復雜度是O(lgN)。

最小堆的刪除和插入邏輯基本類似,如果不做優(yōu)化,時間復雜度也是O(lgN),但是實際實現(xiàn)方案上,做了延遲刪除操作,時間復雜度為O(1)。

延遲刪除即設(shè)置定時器的執(zhí)行回調(diào)函數(shù)為空,每次最小堆超時,將觸發(fā)pop_heap,pop會重新調(diào)整最小堆,最終刪除的定時器將調(diào)整到堆頂,但是回調(diào)函數(shù)不處理。

可以看到PerTickBookkeeping只處理堆頂定時器,時間復雜度O(1)。

最小堆可以使用數(shù)組來進行表示,數(shù)組中,當前下標n的左子節(jié)點為2N + 1,當前下標n的右子節(jié)點小標為2N + 2。

圖片

圖4 最小堆的數(shù)組表示

3. 定時器不同實現(xiàn)對比

3.1 時間復雜度對比

圖片

圖5 不同實現(xiàn)時間復雜度

從上面的介紹來看,時間輪的時間復雜度最小、性能最好。

3.2 使用場景來看

在任務(wù)量小的場景下:最小堆實現(xiàn),可以根據(jù)堆頂設(shè)置超時時間,數(shù)組存儲結(jié)構(gòu),節(jié)省內(nèi)存消耗,使用最小堆可以得到比較好的效果。而時間輪定時器,由于需要維護一個線程用來撥動指針,且需要開辟一個bucket數(shù)組,消耗內(nèi)存大,使用時間輪會較為浪費資源。

在任務(wù)量大的場景下:最小堆的插入復雜度是O(lgN), 相比時間輪O(1) 會造成性能下降。更適合使用時間輪實現(xiàn)。

在業(yè)界,服務(wù)治理的心跳檢測等功能需要維護大量的鏈接心跳,因此時間輪是首選。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 定時器
    +關(guān)注

    關(guān)注

    23

    文章

    3259

    瀏覽量

    115909
  • 程序
    +關(guān)注

    關(guān)注

    117

    文章

    3807

    瀏覽量

    81724
收藏 人收藏

    評論

    相關(guān)推薦

    555定時器

    555定時器555定時器555定時器555定時器555定時器555定時器555
    發(fā)表于 11-10 17:25 ?52次下載

    基于STM32定時器實現(xiàn)毫秒延時函數(shù)

    STM32定時器包含基本定時器、通用定時器和高級定時器,其中TIM6和TIM7是STM32當中的基本定時器,作為初學者,先從最基本的學起最容
    發(fā)表于 10-12 15:54 ?2.5w次閱讀
    基于STM32<b class='flag-5'>定時器</b><b class='flag-5'>實現(xiàn)</b>毫秒延時函數(shù)

    定時器原理以及定時器實現(xiàn)的方式

    定時器原理定時器實現(xiàn)的方式有以下幾種: 基于排序鏈表方式: 通過排序鏈表來保存定時器,由于鏈表是排序好的,所以獲取最小(最早到期)的
    的頭像 發(fā)表于 08-14 11:15 ?6941次閱讀

    STM32基于cubeMX實現(xiàn)定時器點燈

    概述STM32的常見的定時器資源: 系統(tǒng)嘀嗒定時器SysTick、看門狗定時器WatchDog、實時時鐘RTC、基本定時器、通用定時器、高級
    發(fā)表于 11-23 18:21 ?19次下載
    STM32基于cubeMX<b class='flag-5'>實現(xiàn)</b><b class='flag-5'>定時器</b>點燈

    STM32定時器-基本定時器

    ,分為基本定時器,通用定時器和高級定時器。基本定時器 TIM6 和 TIM7 是個 16 位的只能向上計數(shù)的
    發(fā)表于 11-23 18:21 ?32次下載
    STM32<b class='flag-5'>定時器</b>-基本<b class='flag-5'>定時器</b>

    STM32——高級定時器、通用定時器、基本定時器的區(qū)別

    STM32——高級定時器、通用定時器、基本定時器的區(qū)別
    發(fā)表于 11-26 15:21 ?110次下載
    STM32——高級<b class='flag-5'>定時器</b>、通用<b class='flag-5'>定時器</b>、基本<b class='flag-5'>定時器</b>的區(qū)別

    SysTick 定時器

    11.1關(guān)于 SysTick 定時器SysTick定時器(又名系統(tǒng)滴答定時器)是存在于Cortex-M3的定時器,只要是ARM Cote
    發(fā)表于 12-05 14:51 ?9次下載
    SysTick <b class='flag-5'>定時器</b>

    labview定時器實現(xiàn)實例分享

    labview定時器實現(xiàn)實例分享
    發(fā)表于 01-11 09:35 ?26次下載

    使用555定時器實現(xiàn)延時關(guān)燈

    使用555定時器實現(xiàn)延時關(guān)燈
    發(fā)表于 11-21 14:54 ?11次下載

    定時器作用及實現(xiàn)定時器數(shù)據(jù)結(jié)構(gòu)選取介紹1

    定時器在各種場景都需要用到,比如游戲的Buff實現(xiàn),Redis中的過期任務(wù),Linux中的定時任務(wù)等等。顧名思義,定時器的主要用途是執(zhí)行定時
    的頭像 發(fā)表于 04-21 15:20 ?1323次閱讀
    <b class='flag-5'>定時器</b>作用及<b class='flag-5'>實現(xiàn)</b><b class='flag-5'>定時器</b>數(shù)據(jù)結(jié)構(gòu)選取介紹1

    定時器作用及實現(xiàn)定時器數(shù)據(jù)結(jié)構(gòu)選取介紹2

    定時器在各種場景都需要用到,比如游戲的Buff實現(xiàn),Redis中的過期任務(wù),Linux中的定時任務(wù)等等。顧名思義,定時器的主要用途是執(zhí)行定時
    的頭像 發(fā)表于 04-21 15:20 ?1274次閱讀
    <b class='flag-5'>定時器</b>作用及<b class='flag-5'>實現(xiàn)</b><b class='flag-5'>定時器</b>數(shù)據(jù)結(jié)構(gòu)選取介紹2

    什么是軟件定時器?軟件定時器實現(xiàn)原理

    軟件定時器是用程序模擬出來的定時器,可以由個硬件定時器模擬出成千上萬個軟件定時器,這樣程序在需要使用較多
    的頭像 發(fā)表于 05-23 17:05 ?3046次閱讀

    STM32如何使用定時器實現(xiàn)微秒(us)級延時?

    如何使用定時器實現(xiàn)微秒級延時的步驟: 步驟 1:配置定時器 首先,需要選擇個適合的定時器。大多數(shù)STM32微控制
    的頭像 發(fā)表于 11-06 11:05 ?6808次閱讀

    定時器設(shè)計實現(xiàn)

    返回ITimer類型的共享指針。其中ITimer類中定義了start和stop方法,用于啟動或停止當前定時器。 TimerManager還有個內(nèi)部類TimerMessageQueue用于實現(xiàn)
    的頭像 發(fā)表于 11-08 16:50 ?732次閱讀

    如何實現(xiàn)個軟件定時器

    在Linux,uC/OS,F(xiàn)reeRTOS等操作系統(tǒng)中,都帶有軟件定時器,原理大同小異。典型的實現(xiàn)方法是:通過個硬件定時器產(chǎn)生固定的時鐘節(jié)拍,每次硬件
    的頭像 發(fā)表于 04-29 11:00 ?851次閱讀
    主站蜘蛛池模板: 秋霞电影网视频一区二区三区 | 肉动漫无修在线播放 | 秋霞三级理伦免费观看 | 中文字幕本庄优花喂奶 | 老太婆性BBWBBW| 三级黄色片免费观看 | 色悠悠电影网 | 久久高清一本无码 | 蜜桃视频无码区在线观看 | 91久久精品一区二区三区 | 啦啦啦 中文 日本 韩国 免费 | 超碰在线视频 免费 | 加勒比一本之道高清视频在线观看 | 99国产精品欲AV蜜桃臀麻豆 | avove旗袍丝袜高跟啪啪 | 亚洲乱码国产一区三区 | 国产成人一区免费观看 | 成人精品视频网站 | 欧美激情久久久久久久大片 | 久久精品国产欧美日韩99热 | 亚洲人成网站在线播放 | 欧美最猛性xxxxx亚洲精品 | 欧美亚洲另类热图 | 与子敌伦刺激对白亂輪亂性 | 99精品免费观看 | 熟女人妻久久精品AV天堂 | aa级毛片毛片免费观看久 | 日本动漫henta videos | 欧美日韩精品 | 亚洲电影成人 成人影院 | 十分钟视频影院免费 | 国产精品久久久久久久人热 | 亚洲看片网站 | 欧美美女论坛 | 九九夜夜妹子 | 亚洲欧美精品无码一区二在线 | 亚洲第一页在线播放 | 久久综合久综合久久鬼色 | 国产一区二区波多野结衣 | 无码人妻丰满熟妇区五十路久久 | 999人在线精品播放视频 |