• <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>
            Creative Commons License
            本Blog采用 知識共享署名-非商業(yè)性使用-禁止演繹 3.0 Unported許可協(xié)議 進行許可。 —— Fox <游戲人生>

            游戲人生

            游戲人生 != ( 人生 == 游戲 )
            站點遷移至:http://www.yulefox.com。請訂閱本博的朋友將RSS修改為http://feeds.feedburner.com/yulefox
            posts - 62, comments - 508, trackbacks - 0, articles - 7

            門窺多線程安全

            Posted on 2008-01-10 04:02 Fox 閱讀(2719) 評論(10)  編輯 收藏 引用 所屬分類: G游戲編程

            Author: Fox

            一、多線程安全的引入:

            關(guān)于什么是多線程、為什么使用多線程的問題,大家可以看看Jim Beveridge & Robert Wiener的《Win32多線程程序設(shè)計》(侯捷 譯),或者其他隨便一本提到多線程的書或文章。這里只是提到Windows環(huán)境下多線程容易引發(fā)的問題和解決辦法。

            1、線程在時間片結(jié)束時退出做不到

            由于Windows屬于分時操作系統(tǒng),系統(tǒng)會為每個線程分配響應(yīng)的時間片使其工作,絕大多數(shù)線程不可能在時間片結(jié)束的時候完成其工作,而下一個時間片就有可能分配給其他線程。

            2、線程獨立做不到

            如果線程間不存在依賴關(guān)系,即線程A的執(zhí)行不依賴于線程B的執(zhí)行,此時即使線程B被打斷,由于線程獨立,所以二者也可以相安無事。

            然而,在多線程解決方案中,線程間的通信是頻繁而且必要的。線程通信主要有兩種情況:

            1) 多個線程共享相同資源;

            2) 一個線程的執(zhí)行依賴于其他線程的結(jié)果或執(zhí)行情況。

            這時,我們就需要實現(xiàn)共享資源及線程執(zhí)行的同步。

            二、多線程安全的解決方案:

            因此,多線程安全的目標就是實現(xiàn)共享資源的互斥訪問和線程執(zhí)行的同步通信。

            通過對操作系統(tǒng)的學習,我們知道線程同步主要有以下方法:

            1) 臨界段(Critical Section)

            a) 臨界資源的取舍,宜少不宜多,宜短不宜長,一個線程只能最多等待一個臨界段;

            b) 無法偵測一個臨界段是否已經(jīng)被放棄;

            c) 臨界段屬于用戶對象。

            2) 互斥鎖(Mutex)

            同臨界段一樣,互斥鎖也主要用于保證資源的原子訪問,二者的不同之處在于:

            a) 互斥鎖屬于可具名內(nèi)核對象;

            b) 互斥鎖可以跨進程使用,臨界段只能用于同一進程內(nèi);

            c) 互斥鎖可以指定等待時間,而且可以等待其他內(nèi)核對象。

            3) 事件(Event)

            a) 事件重置具有人工重置和自動重置兩種方式,簡單說來,二者分別用于多讀和單寫;

            b) 事件主要用于線程間相互通知(喚醒);

            C) 事件屬于可具名內(nèi)核對象。

            4) 信號量(Semaphore)

            a) 信號量屬于可具名內(nèi)核對象;

            b) 信號量沒有擁有者,可被任一線程釋放;

            關(guān)于Win32中這四種對象的使用和要點,更詳細的介紹可以參照《Win32多線程程序設(shè)計》或《Windows核心編程》(Jeffrey Richter)等。

            三、多線程安全的實現(xiàn):

            將對數(shù)據(jù)(對象、模型、消息、Socket)的I/O處理放在同一個I/O線程中,保證如隊列的push/pop操作、鏈表的insert/delete操作、文件的write操作、socket的recv/send操作、全局變量的write操作等的互斥訪問。

            新建獨立模塊,尤其是使用第三方庫的獨立模塊,大多會創(chuàng)建獨立的新線程。此時就需要對新線程中的數(shù)據(jù)操作加以注意,可以通過對操作數(shù)據(jù)的加鎖訪問解決同步問題,當然,更常見的處理方式是將新線程中的數(shù)據(jù)操作發(fā)送到專門的I/O線程中處理。

            總之,多線程安全是個常說常新的話題,現(xiàn)在有人提出Lock-Free數(shù)據(jù)結(jié)構(gòu)的解決方案(Maged M. Michael),也有所謂的Wait-Free的解決方案(Maurice Herlihy),而國內(nèi)網(wǎng)游界的大牛云風同學更是提出了單線程多進程的觀點和解決方案(因為不了解,按字面有可能存在斷章取義之嫌)。但不管怎么樣,從中至少可以看出,多線程,說來話長。

            零零散散、東拉西扯、不知所云的講了一些東西,未必正確,更不能當作知識。全當是對上次的承諾有個交代。

            /*****************************************************************************
            ?想把多線程的問題搞明白,不是說看看操作系統(tǒng)教材,寫點多線程讀寫的代碼就夠的。且不論孰是孰非,
            ?單就網(wǎng)上諸多高手新學對加鎖策略鋪天蓋地的爭執(zhí)說辭甚至相互批判指責,足可見多線程開發(fā)并非只言
            ?片語即可挑明。
            ?為防止陷入細節(jié)爭論,這里先作聲明:小文僅就所學略抒拙見,無意引起爭端……
            *****************************************************************************/

            Feedback

            # re: 門窺多線程安全  回復(fù)  更多評論   

            2008-01-10 04:11 by Fox
            因為今明兩天要去雅安碧峰峽一游,所以,沙發(fā)留給自己了,也對到這兒的兄弟們有個交代……

            # re: 門窺多線程安全  回復(fù)  更多評論   

            2008-01-10 08:18 by mugong
            感覺LZ寫得比較淺,只有借鑒作用。該怎么寫,我也不大清楚o(∩_∩)o...哈哈

            # re: 門窺多線程安全  回復(fù)  更多評論   

            2008-01-10 09:35 by <a href=http://minidx.com>minidxer</a>
            到處玩,真是開心

            # re: 門窺多線程安全  回復(fù)  更多評論   

            2008-01-10 22:41 by 漂泊者
            兄弟現(xiàn)在深入研究技術(shù)了,靠,我現(xiàn)在是廢了
            搞得最多的是開會了。。。赫赫!

            # re: 門窺多線程安全  回復(fù)  更多評論   

            2008-01-11 18:15 by Fox
            @mugong
            現(xiàn)在不想在blog里寫帶代碼的東西,精力太有限了,只想在這兒放松一下,還請原諒 :(

            # re: 門窺多線程安全  回復(fù)  更多評論   

            2008-01-11 18:16 by Fox
            @minidxer
            是啊,平時工作比較辛苦,出去玩一玩,放松一下啊 :)

            # re: 門窺多線程安全  回復(fù)  更多評論   

            2008-01-11 18:17 by Fox
            @漂泊者
            也沒有多深入,只是想在年輕的時候做點事情……

            今天看到幾句話,很有道理,與各位辛勤工作的朋友共勉:
            不能餓了才吃,不能渴了才喝,不能困了才睡,不能累了才歇,不能病了才檢查。

            # re: 門窺多線程安全  回復(fù)  更多評論   

            2008-01-11 18:45 by <a href=http://minidx.com>minidxer</a>
            開心阿~
            現(xiàn)在我是沒心情出去玩

            # re: 門窺多線程安全  回復(fù)  更多評論   

            2008-01-14 14:44 by ms.gofixiao
            果然是東拉拉西扯扯哦o(∩_∩)o...,希望完善一下。

            # re: 門窺多線程安全  回復(fù)  更多評論   

            2008-01-14 14:48 by Fox
            @ms.gofixiao
            恩,因為畢竟不是對多線程的技術(shù)要點都有一個全面的把握,所以要想好好寫,也不容易。。
            精品久久久久久无码专区 | 久久亚洲AV成人无码国产 | 久久播电影网| 亚洲精品国产综合久久一线| 国产99久久久国产精品小说| 韩国无遮挡三级久久| 久久国产精品免费一区二区三区| 久久综合九色综合网站| 久久99国产精品久久| 少妇人妻综合久久中文字幕| 狠狠狠色丁香婷婷综合久久五月| 欧美一区二区久久精品| 国产亚洲婷婷香蕉久久精品| 久久精品人人做人人爽电影| 日本一区精品久久久久影院| 欧洲人妻丰满av无码久久不卡| 久久久久噜噜噜亚洲熟女综合| 成人免费网站久久久| 久久久久久国产a免费观看黄色大片 | 国产精品久久久久久久久久免费| 久久久亚洲AV波多野结衣| 国产福利电影一区二区三区久久久久成人精品综合 | 久久精品亚洲日本波多野结衣| 久久国产综合精品五月天| 国产情侣久久久久aⅴ免费| 三级三级久久三级久久| 国产成人99久久亚洲综合精品| 久久亚洲精品无码AV红樱桃| 久久久久久久波多野结衣高潮| 久久av高潮av无码av喷吹| 亚洲成色999久久网站| 久久天天躁狠狠躁夜夜96流白浆| 亚洲国产日韩欧美久久| 久久久精品无码专区不卡| 狠狠精品干练久久久无码中文字幕| 99久久99久久久精品齐齐| 亚洲va久久久噜噜噜久久男同 | 2020久久精品国产免费| 人妻无码中文久久久久专区 | 久久本道久久综合伊人| 国产国产成人久久精品|