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

            之前的文章講過,我設(shè)計的網(wǎng)絡(luò)框架有幾組線程,分別是io、異步、同步、定時器,各個不同應(yīng)用server幾組線程組合形式不盡相同,簡單的可只有io線程,復(fù)雜一點(diǎn)的可io+同步,更復(fù)雜一點(diǎn)的也可io+同步+異步+定時器,總之我以幾組線程的自由組合方式應(yīng)付各種應(yīng)用,在我負(fù)責(zé)的server全是這一套框架實(shí)現(xiàn)的,不管是支持幾萬人連接的服務(wù)器,還是只有幾個用戶連接的內(nèi)部服務(wù)器,這套框架也算是久經(jīng)考驗(yàn),穩(wěn)定運(yùn)行多年,內(nèi)部使用也非常簡單,如給sync線程組發(fā)一個消息只要PostSyncEvent,如果要給異步線程發(fā)一個消息只要發(fā)PostAsyncEvent,雖然只能開發(fā)的時候確定哪個任務(wù)在哪組線程執(zhí)行,但修改還是非常方便的,執(zhí)行體就是一組這樣的函數(shù):

            OnSyncEvent(DWORD dwEvent, DWORD wParam, DWORD lParam);

            OnAsyncEvent(DWORD dwEvent, DWORD wParam, DWORD lParam);

            一眼就知道是在哪個線程組里面執(zhí)行,當(dāng)然有的線程組是一個線程,有的線程組是多個,這涉及到有的資源是不是要加鎖,有經(jīng)驗(yàn)的開發(fā)人員很容易理解。

            說了一下框架才容易理解我的問題,之前定時器是一個獨(dú)立的線程組,同步線程組、異步線程組、io組都沒有定時器功能,定時器觸發(fā)后要發(fā)送消息到相應(yīng)線程組,有的要發(fā)給異步線程組,有的要發(fā)給同步線程組,這就會引起線程切換,這是問題之一,還有一個問題,之前的定時器是由windows的時鐘隊(duì)列實(shí)現(xiàn)的,這個定時器優(yōu)點(diǎn)是很明顯的,定時精確,功能強(qiáng)大,參數(shù)眾多,獨(dú)立線程組,但也有很明顯的問題,如果要刪除一個定時器則有線程依賴,就是要在定時器線程才能刪除定時器,這個依賴約束很大,也很容易引起問題,用起來很不方便,使得一些資源的釋放不能夠即時進(jìn)行。正因?yàn)橛羞@么些問題,也為了使得時鐘模塊更容易移植,我設(shè)計了一個新時鐘模塊,為實(shí)現(xiàn)以下目標(biāo):

            1、無線程依賴,隨便調(diào)用者在哪個線程調(diào)用都可刪除指定的定時器。

            2、和事件消息集成在一個線程內(nèi),實(shí)現(xiàn)無需切換的定時器功能,這樣主線程、同步線程組、異步線程組都可在內(nèi)部處理定時器消息,無需單獨(dú)的定時器線程輔助,方便很多。

            為實(shí)現(xiàn)以上目標(biāo),我引入了libevent里面的minheap管理定時器,并根據(jù)之前管理事件的處理辦法,繼續(xù)使用iocp隊(duì)列管理線程消息,在每個線程組用iocp管理事件,根據(jù)最短觸發(fā)的定時器計算wait時間,這樣就在同一組線程內(nèi)實(shí)現(xiàn)了定時器和事件合并處理,當(dāng)然實(shí)現(xiàn)方法有很多,也可用iocp+WaitableTimer等,也可用apc,但那些實(shí)現(xiàn)的windows烙印都太深刻,雖然精度更高,實(shí)現(xiàn)更容易,我用minheap+iocp隊(duì)列方式的實(shí)現(xiàn)相對來說對windows的依賴較少,因?yàn)樘鎿Q一個iocp隊(duì)列處理事件是很容易的,這樣也方便移植和復(fù)用代碼。經(jīng)這樣修改之后,各個線程組包括主線程都可處理定時器和事件消息,也使得以前雞肋式的主線程終于可當(dāng)同步線程發(fā)揮作用,以前的定時器線程組也不一定需要了,既減少了線程,也減少了切換,現(xiàn)在各個線程組(包括主線程)都有完全一致的消息處理和時鐘處理函數(shù)。

            事件函數(shù):

            OnTimerEvent(DWORD dwEvent, DWORD wParam, DWORD lParam);

            OnSyncEvent(DWORD dwEvent, DWORD wParam, DWORD lParam);

            OnAsyncEvent(DWORD dwEvent, DWORD wParam, DWORD lParam);

            OnServiceEvent(DWORD dwEvent, DWORD wParam, DWORD lParam);

            定時器函數(shù):

            OnTimerTimer(TlsInfo *ptls, EventTimer *et);

            OnSyncTimer(TlsInfo *ptls, EventTimer *et);

            OnAsyncTimer(TlsInfo *ptls, EventTimer *et);

            OnIoTimer(TlsInfo *ptls, EventTimer *et);

            OnServiceTimer(TlsInfo *ptls, EventTimer *et);

            可以給線程組增加定時器刪除定時器

            AddTimerAddSyncTimerAddAsyncTimerAddServiceTimerAddIoTimer

            DelTimerDelSyncTimerDelAsyncTimerDelServiceTimerDelIoTimer

            可給各線程組發(fā)消息

            PostTimerEventPostSyncEventPostAsyncEventPostServiceEvent

             

            這套框架是我多年服務(wù)器端開發(fā)的得意之作,體現(xiàn)了我簡潔實(shí)用的設(shè)計思想,用起來非常方便,可任意組合,適應(yīng)各種需求的應(yīng)用,由于除主線程之外的io線程組、同步線程組、異步線程組、定時器線程都是可以關(guān)、開1個、開多個,所以組合非常靈活,開1個可當(dāng)同步線程,開多個可當(dāng)異步線程(內(nèi)部搶資源),關(guān)閉就不存在該組線程,即使是io線程組也是可關(guān)的,這樣就使得這套框架不僅僅用在標(biāo)準(zhǔn)server上,就算是當(dāng)作一般的消息隊(duì)列服務(wù)器也沒問題,高度的靈活性使得這套框架可適應(yīng)各種規(guī)模的應(yīng)用,這次對定時器的改造使得這種組合更靈活,雖然現(xiàn)在的實(shí)現(xiàn)方法定時器的精度有一些下降,但瑕不掩瑜,這樣改造之后功能無疑是更強(qiáng)大了。

            Posted on 2010-10-03 14:23 袁斌 閱讀(708) 評論(0)  編輯 收藏 引用 所屬分類: 游戲開發(fā)
            A级毛片无码久久精品免费| 久久91精品国产91| 99久久婷婷免费国产综合精品| 日产精品99久久久久久| 久久电影网一区| 日本亚洲色大成网站WWW久久| 久久久久亚洲AV无码麻豆| 国产精久久一区二区三区| 2021国产精品久久精品| 国产精品99久久久久久宅男| 久久青青草原亚洲av无码app | 欧美激情一区二区久久久| 国产精品久久亚洲不卡动漫| 久久亚洲精品成人无码网站| AV狠狠色丁香婷婷综合久久| 囯产精品久久久久久久久蜜桃| 99久久国产综合精品网成人影院| 伊人色综合久久天天人手人婷 | 亚洲午夜无码AV毛片久久| 久久婷婷五月综合97色| 久久综合久久综合亚洲| 久久国产美女免费观看精品| 99精品国产在热久久无毒不卡| 亚洲综合精品香蕉久久网| 中文字幕精品久久| 亚洲国产成人精品久久久国产成人一区二区三区综 | 国产亚州精品女人久久久久久 | 国产精品亚洲综合专区片高清久久久 | 日本人妻丰满熟妇久久久久久| 蜜桃麻豆WWW久久囤产精品| 久久五月精品中文字幕| 亚洲国产精品久久久久婷婷老年| 精品999久久久久久中文字幕| 69国产成人综合久久精品| 久久久久99精品成人片直播| 久久男人Av资源网站无码软件| 奇米综合四色77777久久| 亚洲欧洲日产国码无码久久99| 亚洲国产精品无码久久久不卡| 久久精品麻豆日日躁夜夜躁| 综合久久国产九一剧情麻豆|