青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 94, comments - 250, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

Nebula3的多線程架構(gòu)

Posted on 2008-12-14 21:57 Condor 閱讀(685) 評論(0)  編輯 收藏 引用

Nebula3的代碼運行在兩種根本不同的方案中. 第一種方案我稱之為”Fat Thread”. 一個Fat Thread在一個線程中運行一個完整的子系統(tǒng)(如渲染, 音頻, AI, 物理, 資源管理), 并且基本上鎖定在一個特定的核心上.

第二種類型的線程我叫它”Job”. 一個job是一些數(shù)據(jù)和用于處理這些數(shù)據(jù)的包裝成C++對象的代碼. 工作調(diào)度程序掌管了Job對象, 并且把工作分配給低負載的核心來保持它們一直處于忙碌狀態(tài).

顯然, 挑戰(zhàn)就是設(shè)計一個經(jīng)過全面考慮的系統(tǒng), 以保持所有的核心一直均勻地忙碌著. 這不但意味著連續(xù)的活動需要在游戲每幀的空閑時期內(nèi)輪流交替, 而且要求job對象不得不事先(如每幀前)創(chuàng)建好, 這樣才能在各種Fat Thread空閑時填充當前幀的空白.

這是我希望進行更多試驗和調(diào)整的地方.

第二個挑戰(zhàn)就是讓程序員的工作盡量的簡單. 一個游戲應(yīng)用程序員(邏輯程序員)在任何時候都不應(yīng)該關(guān)心他運行在一個多線程的環(huán)境中, 不應(yīng)該擔心會產(chǎn)生死鎖或改寫了其它線程的數(shù)據(jù), 也不應(yīng)該瞎搞一些臨界區(qū), 事件和信號量. 同樣, 整個引擎的架構(gòu)也不應(yīng)該是”脆弱的”. 大部分傳統(tǒng)的多線程代碼在一定程度上都會發(fā)生紊亂, 或者忘記了臨界區(qū)而打亂數(shù)據(jù).

當線程間需要進行數(shù)據(jù)共享和通信時, 多線程就變得很棘手. 像兩個臨界區(qū)這樣的解決方案也會導致脆弱代碼問題.

從大的角度來說, Nebula3通過一個”并行Nebula”的概念解決了這個兩個問題. 其思想就是運行了一個完整子系統(tǒng)的”Fat Thread”都有自己的最小Nebula運行庫, 這個最小運行庫剛好包含了這個子系統(tǒng)需要的部分. 因此, 如果這個運行在它自己線程中的子系統(tǒng)需要進行文件訪問, 它會有一個跟其它Fat Thread完全分離的文件服務(wù)器(file server). 這個解決方案的優(yōu)點是, 大部分Nebula中的代碼都不需要知道它運行在一個多線程的環(huán)境中, 因為在fat thread之間沒有數(shù)據(jù)進行共享. 運行著的每個最小Nebula內(nèi)核是跟其它Nebula內(nèi)核完全隔離的. 缺點就是, 重復的數(shù)據(jù)會浪費一些內(nèi)存, 但是我們只是占用幾KB, 而不是MB.

這些數(shù)據(jù)冗余消除了細密的鎖定, 并且解決把程序員從思考每一行代碼的多線程安全性中解放了出來.

當然, 從某種意義上說Fat Thread間的通信是肯定會發(fā)生的, 要不然這整個思想就沒有意義了. 方法就是建立一個且只有一個的標準通信系統(tǒng), 并且保證這個通信系統(tǒng)是可靠而快速的. 這就是消息系統(tǒng)的由來. 要跟一個Fat Thread通信的話只有發(fā)送一個消息給它. 消息是一個簡單的C++對象, 它包含了一些帶有g(shù)et/set方法的數(shù)據(jù). 通過這個標準的通信手段, 實際上只有消息子系統(tǒng)才需要是線程安全的(同樣, 訪問跟消息相關(guān)的資源時, 如內(nèi)存緩沖區(qū), 必須受到約束, 因們它們代表了共享數(shù)據(jù)). (xoyojank: 我說咋那么多Message…)

這樣雖然解決了Fat Thread方案中大多數(shù)的多線程問題, 但沒有解決Job對象的任何事情. Nebula3很有可能需要約束一個Job對象能做什么和不能做什么. 最直接的行為就是限制job做內(nèi)存緩沖區(qū)的計算. 那樣的話, job中就不能存在復雜的運行庫(不能文件I/O, 不能訪問渲染等等). 如果這樣還不夠的話, 必須定義一個”job運行時環(huán)境”, 就像Fat Thread中的那樣. 因為一個job不會發(fā)起它自己的線程, 而且還會被調(diào)度到一個已經(jīng)存在的線程池中. 就這個方面來說, 這不存在什么問題.

到現(xiàn)在為止(xoyojank: 2007/01/21, 最新版本已經(jīng)實現(xiàn)了多數(shù)子系統(tǒng)的多線程化), 只有IO子系統(tǒng)作為概念證明在Fat Thread中得到實現(xiàn), 并且它運行得很今人滿意. 在做傳統(tǒng)的同步IO工作時, 一個Nebula3程序可以直接調(diào)用本地線程的IO子系統(tǒng). 所以像列出文件夾的內(nèi)容或刪除一個文件, 只會調(diào)用一個簡單的C++方法. 對于異步IO工作, 定義了一些常見的IO操作消息(如ReadStream, WriteStream, CopyFile, DeleteFile, 等等). 進行異步IO只需要幾行代碼: 創(chuàng)建一個消息對象, 填充數(shù)據(jù), 并發(fā)送這個消息到一個IOInterface單件. 如果必要的話, 這可能會需要等待和輪詢異步操作.

這樣的好處就是, 整個IO子系統(tǒng)沒有一行多線程意義上的代碼, 因為各個在不同的Fat Thread中的IO子系統(tǒng)是完全隔離的(當然, 同步肯定會發(fā)生在一些IO操作上, 但那都留給操作系統(tǒng)了).


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久蜜桃香蕉精品一区二区三区| 欧美一区=区| 欧美激情亚洲综合一区| 另类激情亚洲| 日韩视频免费观看高清在线视频| 最新成人av在线| 国产精品a久久久久久| 欧美亚洲一区三区| 久久免费偷拍视频| 亚洲国产日韩在线一区模特| 91久久久国产精品| 国产精品久久国产三级国电话系列| 欧美亚洲网站| 久热国产精品| 亚洲一区二区av电影| 亚洲一区免费视频| 在线成人小视频| 日韩午夜av| 国产中文一区二区| 亚洲国产精品ⅴa在线观看| 国产精品九九| 欧美激情国产高清| 国产精品扒开腿爽爽爽视频 | 欧美剧在线观看| 亚洲一卡久久| 狠狠色综合网站久久久久久久| 欧美v日韩v国产v| 亚洲欧美日韩区| 亚洲激情视频| 久久国产精品久久w女人spa| 日韩视频中午一区| 亚洲精品一区二区三区四区高清| 国产精品美女在线观看| 欧美福利一区| 国产一区二区三区观看| 中文精品99久久国产香蕉| 在线观看国产一区二区| 亚洲图片在区色| 最新国产成人av网站网址麻豆| 亚洲欧美日韩国产中文| 亚洲视频www| 欧美大片一区二区| 久久亚洲国产成人| 国产农村妇女精品| 中文一区二区| 亚洲天堂久久| 欧美日韩视频在线| 欧美一区二区视频在线观看2020| 欧美精品久久99| 免费亚洲电影在线| 国产一区二区三区在线观看网站 | 翔田千里一区二区| 亚洲桃花岛网站| 欧美人与禽猛交乱配| 欧美黄色成人网| 在线看欧美日韩| 欧美一区二区| 久久精品国产v日韩v亚洲| 国产精品久久久久高潮| 一区二区三区免费在线观看| 日韩午夜精品| 欧美人体xx| 亚洲精品影视在线观看| 一本大道久久a久久综合婷婷| 女仆av观看一区| 91久久国产综合久久| 日韩午夜三级在线| 欧美另类久久久品| 亚洲精品中文在线| 亚洲图片欧洲图片av| 国产精品大片免费观看| 亚洲一区视频在线观看视频| 亚洲欧美综合国产精品一区| 欧美午夜精品理论片a级按摩| 一本色道久久综合亚洲精品婷婷 | 日韩网站在线观看| 欧美精品在线观看播放| 日韩视频一区二区三区| 亚洲欧美日韩在线观看a三区| 国产精品私人影院| 欧美亚洲网站| 免费人成精品欧美精品| 亚洲日本va午夜在线影院| 欧美精品啪啪| 午夜精品久久久久久久久久久| 久久精品国产清自在天天线| 在线观看成人av电影| 欧美激情精品久久久久久| 亚洲最新在线| 麻豆成人精品| av72成人在线| 国产一区免费视频| 欧美激情久久久久久| 亚洲香蕉网站| 欧美a级片网| 亚洲综合色婷婷| 一区国产精品| 国产精品国产三级国产a| 欧美自拍偷拍午夜视频| 亚洲精品国产无天堂网2021| 午夜在线成人av| 亚洲国产精品成人精品| 国产精品久久777777毛茸茸| 久久国产欧美| 一区二区久久久久久| 久久一区二区三区四区五区| 一本色道久久综合亚洲精品高清 | 久久久精品日韩| 亚洲人成小说网站色在线| 国产精品久久久999| 欧美成熟视频| 欧美在线视屏| 亚洲午夜激情| 亚洲国产精品一区在线观看不卡| 久久av一区二区三区漫画| 99热免费精品| 亚洲国产精品ⅴa在线观看| 国产精品爽黄69| 欧美精品综合| 久久综合给合久久狠狠色| 亚洲欧美国产另类| 在线视频欧美日韩| 亚洲精品国产拍免费91在线| 久久综合福利| 久久九九国产| 久久精品男女| 欧美在线高清视频| 99re热这里只有精品免费视频| 激情久久久久久久久久久久久久久久| 欧美日韩综合久久| 久久综合伊人77777蜜臀| 欧美中文字幕视频| 亚洲欧美另类在线观看| 亚洲午夜一区二区三区| 一区二区三区欧美在线| 亚洲精品自在久久| 亚洲日本精品国产第一区| 欧美激情在线狂野欧美精品| 欧美成人中文| 欧美电影免费观看高清完整版| 久久乐国产精品| 久久色中文字幕| 久久综合导航| 免费在线成人av| 欧美高清视频一二三区| 欧美大色视频| 亚洲国产日韩欧美| 亚洲激情中文1区| 91久久嫩草影院一区二区| 亚洲黄色免费电影| 亚洲品质自拍| 一区二区成人精品| 亚洲欧美中文另类| 久久成人18免费网站| 久久久91精品国产一区二区精品| 久久国产精品久久久久久| 久久久亚洲成人| 欧美韩日亚洲| 欧美性大战久久久久久久蜜臀| 国产精品国内视频| 国产日韩欧美在线看| 狠狠做深爱婷婷久久综合一区 | 欧美日韩无遮挡| 国产精品女主播在线观看 | 欧美极品色图| 欧美三区不卡| 国产日韩在线一区二区三区| 精品成人国产在线观看男人呻吟| 91久久精品国产| 午夜精品久久久久久久蜜桃app | 亚洲小说欧美另类社区| 午夜精品999| 欧美成人精品| 国产精品久久久久久久久久免费 | 国产精品久久久久999| 国产综合av| 99日韩精品| 久久久精彩视频| 亚洲区一区二| 欧美伊久线香蕉线新在线| 欧美ed2k| 国产视频一区在线| 日韩一级裸体免费视频| 久久精品免视看| 野花国产精品入口| 美女视频网站黄色亚洲| 国产精品www网站| 亚洲黄网站在线观看| 欧美在线观看网站| 亚洲激情校园春色| 久久久久综合一区二区三区| 欧美日韩精品国产| 亚洲福利专区| 久久er99精品| 99精品欧美一区二区三区综合在线| 久久久av水蜜桃| 国产精品入口福利| 亚洲最新在线视频| 欧美成在线视频| 久久精品视频在线看|