• <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>

            一動(dòng)不如一靜

            C++博客 首頁(yè) 新隨筆 聯(lián)系 聚合 管理
              20 Posts :: 0 Stories :: 10 Comments :: 0 Trackbacks
            前段時(shí)間用了ACE_TP_Reactor做了一個(gè)東西,但是對(duì)這塊東西不是很有底,所以借著假期仔細(xì)的看了一下這一塊的東西,又上網(wǎng)查了一下相關(guān)的資料。

            在Addison-Wesley - C++NetworkProgrammingVol2的4.3 The ACE_TP_Reactor Class中有這樣幾句話,讓我足足想了一天。

            1.Multiple threads running an ACE_TP_Reactor event loop can process events concurrently on different handles
            2.They can also dispatch timeout and I/O callback methods concurrently on the same event handler
            3.The only serialization in the ACE_TP_Reactor occurs when I/O events occur concurrently on the same handle
            4.After a thread obtains a set of active handles from select(), the other reactor threads dispatch from that handle set instead of calling select() again

            其實(shí)上面的3句話主要表達(dá)這樣的幾層含義
            1.并行處理不同handle上的事件
            2.并行處理同一event handler上的超時(shí)回調(diào)函數(shù)和I/O回調(diào)函數(shù)
            3.多個(gè)線程串行處理同一個(gè)handle上的I/O事件。
            4.雖然TP_Reactor是用leader/follow模式輪流調(diào)用select,但是如果一個(gè)select()獲得了多個(gè)激活的handle,那么其他的線程會(huì)分發(fā)這些handle ,而不是去再次調(diào)用select.
            ?(這點(diǎn)還沒(méi)有想通,也沒(méi)有看見(jiàn)是如何實(shí)現(xiàn)的?)

            “多個(gè)線程串行處理同一個(gè)handle上的I/O事件”
            ??? ?? 這個(gè)是如何達(dá)到的呢?ACE源碼中,當(dāng)處理I/O事件的時(shí)候,會(huì)將HANDLE掛起,使得不再對(duì)該HANDLE做事件偵聽(tīng)。來(lái)達(dá)到同一個(gè)handle上的I/O事件是被多個(gè)線程串行地處理。

            "并行處理同一event handler上的超時(shí)回掉函數(shù)和I/O回調(diào)函數(shù)"
            ??? ?? 這樣好像就比較麻煩了。因?yàn)檫@就意味著TP_Reactor只保證同一個(gè)handle下不會(huì)有多線程同時(shí)調(diào)用I/O事件,但是卻有可能同時(shí)調(diào)用超時(shí)回調(diào)函數(shù)和I/O回調(diào)函數(shù)。如果在這兩個(gè)函數(shù)中有對(duì)數(shù)據(jù)的訪問(wèn)和操作,這就意味著需要有鎖的引入。例外,如果在定時(shí)器處理中,超過(guò)定時(shí)的事件間隔,就會(huì)有令一個(gè)線程再次調(diào)用定時(shí)器的處理函數(shù),一下子引入了很多同步的問(wèn)題。如何解決這個(gè)問(wèn)題呢?

            方法一:

            ??? ??? ??? 更改ACE的源碼,象處理socket事件一樣,在處理定時(shí)事件的時(shí)候,也把HANDLE掛起。來(lái)自http://cpunion.cnblogs.com/archive/2005/08/09/210941.html

            int
            ACE_TP_Reactor::handle_timer_events?(
            int?&?/*event_count*/,
            ?????????????????????????????????????ACE_TP_Token_Guard?
            &guard)
            {
            ??
            //?Get?the?current?time
            ??ACE_Time_Value?cur_time?(this->timer_queue_->gettimeofday?()?+
            ???????????????????????????
            this->timer_queue_->timer_skew?());

            ??
            //?Look?for?a?node?in?the?timer?queue?whose?timer?<=?the?present
            ??
            //?time.
            ??ACE_Timer_Node_Dispatch_Info?info;

            ??
            if?(this->timer_queue_->dispatch_info?(cur_time,
            ?????????????????????????????????????????info))
            ????{
            ????????
            //?********?fixed?by?lijie?***********
            ????????if?(info.type_->get_handle?()?!=?ACE_INVALID_HANDLE)
            ????????{
            ????????????
            if?(this->is_suspended_i?(info.type_->get_handle?()))
            ????????????????
            return?0;

            ????????????
            this->suspend_handler?(info.type_->get_handle?());
            ????????}
            ????????
            //?********?end?**********************

            ??????
            const?void?*upcall_act?=?0;

            ??????
            //?Preinvoke.
            ??????this->timer_queue_->preinvoke?(info,
            ?????????????????????????????????????cur_time,
            ?????????????????????????????????????upcall_act);

            ??????

            ??????
            //?Release?the?token?before?dispatching?notifies
            ??????guard.release_token?();

            ??????
            //?call?the?functor
            ??????this->timer_queue_->upcall?(info,
            ??????????????????????????????????cur_time);

            ??????
            //?Postinvoke
            ??????this->timer_queue_->postinvoke?(info,
            ??????????????????????????????????????cur_time,
            ??????????????????????????????????????upcall_act);

            ??????
            //?We?have?dispatched?a?timer
            ??????return?1;
            ????}

            ??
            return?0;
            }

            handle_timer處理完以后,返回以前,加上這句話
            this->reactor ()->resume_handler (this->get_handle ());

            當(dāng)然別忘了為Handler編寫(xiě)get_handle()函數(shù):
            ACE_HANDLE?Test_Handler::get_handle?()?const
            {
            ????
            return?this->peer?().get_handle?();
            }


            方法二:
            ??? ?? ?? ?? 利用ACE_PipeACE_Message_Queue把所有的事件都排隊(duì)到同一個(gè)I/O HANDLE上去,再由ACE_TP_Reactor通過(guò)多個(gè)線程順序串行地觸發(fā)我們舊的event_handler來(lái)處理這些已經(jīng)排好隊(duì)的事件/消息。我比較贊成用這樣方法。該方法來(lái)自:http://blog.csdn.net/zhdaniel/archive/2006/06/29/850888.aspx
            ???

            ??? ??


            方法三:
            ??? ?? ?? ?? ^_^干脆就不要對(duì)同一個(gè)event? handler注冊(cè)I/O事件和其他事件。





            posted on 2006-10-07 11:29 一動(dòng)不如一靜 閱讀(3101) 評(píng)論(1)  編輯 收藏 引用 所屬分類(lèi): ACE

            Feedback

            # re: 關(guān)于ACE_TP_Reactor 2012-11-08 09:30 aa
            ACE_TP_Reactor ,register_handler(this, READ_MASK|WRITE_MASK)
            只響應(yīng)handle_output,handle_input不響應(yīng),請(qǐng)問(wèn)是什么原因?  回復(fù)  更多評(píng)論
              

            综合久久一区二区三区| 国产激情久久久久影院小草| 精品水蜜桃久久久久久久| 97久久国产亚洲精品超碰热| 久久亚洲精品国产亚洲老地址| 久久综合狠狠综合久久97色| 国产精品成人99久久久久| 91久久成人免费| 久久精品国产精品亚洲下载| 久久免费香蕉视频| 蜜桃麻豆WWW久久囤产精品| 97久久婷婷五月综合色d啪蜜芽| 人妻无码αv中文字幕久久琪琪布| 久久久久久久91精品免费观看 | www.久久99| 久久美女网站免费| 久久综合精品国产一区二区三区| 欧美日韩中文字幕久久久不卡| 中文字幕久久精品 | 久久午夜无码鲁丝片秋霞| 久久久久人妻一区二区三区| 99精品国产99久久久久久97| 精品一区二区久久久久久久网站| 青青青国产成人久久111网站| 国产福利电影一区二区三区,免费久久久久久久精 | 国产亚洲欧美精品久久久| 99久久国产综合精品五月天喷水 | 精品久久久久久99人妻| 久久这里有精品视频| 乱亲女H秽乱长久久久| 99久久人人爽亚洲精品美女| 亚洲国产精品无码久久久久久曰| 一本久道久久综合狠狠爱| 一本大道久久a久久精品综合| 亚洲国产成人精品女人久久久| 日韩精品久久久久久免费| 国产精品成人无码久久久久久 | 亚洲午夜久久久久妓女影院| 久久香蕉国产线看观看99| 久久亚洲国产最新网站| 99久久国产综合精品成人影院|