• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-161  評(píng)論-223  文章-30  trackbacks-0
            結(jié)構(gòu)定義
             1 struct state_machine {
             2     int state;
             3     
             4 };
             5 
             6 enum { 
             7     s1,
             8     s2,
             9     
            10     sn
            11 };
               假設(shè)s1為初始狀態(tài),狀態(tài)變遷為s1->s2->...->sn。

            常規(guī)實(shí)現(xiàn) 
               狀態(tài)機(jī)處理函數(shù)state_machine_handle通常在一個(gè)循環(huán)內(nèi)或被事件驅(qū)動(dòng)框架調(diào)用,輸入data會(huì)隨時(shí)序變化,從而引起狀態(tài)的變遷,偽代碼框架如下。
             1void handle_s1(struct state_machine *sm, void *data)
             2{
             3    //do something about state 1
             4    if(is_satisfy_s2(data))
             5        sm->state = s2;
             6}

             7
             8void handle_s2(struct state_machine *sm, void *data)
             9{
            10    //do something about state 2
            11    if(is_satisfy_s3(data))
            12        sm->state = s3;
            13}

            14
            15void handle_sn_1(struct state_machine *sm, void *data)
            16{
            17    //do something about state n-1
            18    if(is_satisfy_sn(data))
            19        sm->state = sn;
            20}

            21
            22void state_machine_handle(struct state_machine *sm, void *data)
            23{
            24    switch(sm->state){
            25        case s1:
            26            handle_s1(sm,data);
            27            break;
            28            
            29        case s2:
            30            handle_s2(sm,data);
            31            break;            
            32            
            33        case sn:
            34            handle_sn(sm,data);
            35            break;
            36    }

            37}
               sm->state初始化為s1。

            改進(jìn)實(shí)現(xiàn)
               為了免去丑陋的switch case分支結(jié)構(gòu),在state_machine內(nèi)用成員函數(shù)指針handler替代了state,改進(jìn)后的框架如下。
             1struct state_machine;
             2typedef void (*state_handler)(struct state_machine*void*);
             3
             4struct state_machine {
             5    state_handler handler;
             6    
             7}
            ;
             8
             9void handle_s1(struct state_machine *sm, void *data)
            10{
            11    //do something about state 1
            12    if(is_satisfy_s2(data))
            13        sm->handler = handle_s2;
            14}

            15
            16void handle_s2(struct state_machine *sm, void *data)
            17{
            18    //do something about state 2
            19    if(is_satisfy_s3(data))
            20        sm->handler = handle_s3;
            21}

            22
            23void handle_sn_1(struct state_machine *sm, void *data)
            24{
            25    //do something about state n-1
            26    if(is_satisfy_sn(data))
            27        sm->handler = handle_sn;
            28}

            29
            30void state_machine_handle(struct state_machine *sm, void *data)
            31{
            32    sm->handler(sm, data);
            33}
               sm->handler初始化為handle_s1,該方法在性能上應(yīng)略優(yōu)于常規(guī)方法,而且邏輯更清晰自然,非常適合于網(wǎng)絡(luò)流的處理,在nginx中分析http和email協(xié)議時(shí),得到了廣泛應(yīng)用。
            posted on 2016-05-05 09:46 春秋十二月 閱讀(4074) 評(píng)論(1)  編輯 收藏 引用 所屬分類: C/C++

            評(píng)論:
            # re: 一種使用函數(shù)指針實(shí)現(xiàn)狀態(tài)機(jī)的方法 2016-05-04 23:27 | linda
            函數(shù)指針實(shí)現(xiàn)狀態(tài)機(jī)  回復(fù)  更多評(píng)論
              
            久久嫩草影院免费看夜色| 99久久亚洲综合精品网站| 日本精品久久久久久久久免费| 国产精品伦理久久久久久 | 久久久精品人妻一区二区三区蜜桃| 蜜臀久久99精品久久久久久 | 日本欧美久久久久免费播放网| 99久久精品国内| 热RE99久久精品国产66热| 久久综合亚洲欧美成人| 伊人色综合久久| 99精品久久精品一区二区| 一级女性全黄久久生活片免费 | 色综合久久久久综合99| 91精品国产综合久久精品| 久久伊人五月天论坛| 国产精品久久久久久久 | 99国产精品久久| 亚洲国产精品综合久久网络 | 久久精品国产精品亚洲精品| 亚洲成av人片不卡无码久久| 99久久精品这里只有精品| 久久精品人人做人人爽电影| 久久国产视频99电影| AV无码久久久久不卡蜜桃| 亚洲国产精品综合久久一线| 国产精品成人无码久久久久久| 久久夜色精品国产欧美乱| 97精品国产97久久久久久免费 | 亚洲国产天堂久久综合网站| 久久综合给合久久国产免费 | 狠狠综合久久综合88亚洲| 久久影视综合亚洲| 久久精品国产精品亚洲| 7国产欧美日韩综合天堂中文久久久久 | 久久夜色精品国产亚洲| 国产一区二区三区久久| 狠狠色婷婷综合天天久久丁香 | 无码人妻久久一区二区三区免费| 免费精品国产日韩热久久| 香蕉久久夜色精品国产尤物|