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

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

Nebula3學習筆記(2): 核心庫

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

核心子系統

核心庫(Core namespace)實現了這些特性:

  • 一個實現了引用計數的RefCounted基類
  • 一個運行時類型信息系統(RTTI)
  • 一個模板智能指針, 用于處理RefCounted對象的生命周期
  • 一個由類名創建C++對象實例的工廠機制
  • 一個中央Server對象用于建立基本的Nebula3運行環境

對象模型

Nebula3在C++對象模型的基礎之上實現了下面這些新特性:

  • 基于引用計數和智能指針的生命周期管理
  • 基于類名或四字符編碼的對象創建
  • 一個運行時類型信息系統

實現一個新的Nebula3類

當實現一個新的類時首先要考慮它是一個傳統的C++類還是要從Core::RefCounted繼承. 以下幾點可以幫你找到答案:

  • 如果這個類需要使用Nebula3的擴展對象特性, 如引用計數, RTTI等, 則它必須從Core::RefCounted繼承.
  • 如果這個類是一個典型的小工具類, 如動態數組, 數學向量, 或其它相似的東西, 那么它從Core::RefCounted 繼承也沒有什么意義.

從Core::RefCounted類繼承有一些限制:

  • RefCounted派生類不應該在棧上創建對象, 因為棧對象的生命周期是由C++來管理的(他們會在離開當前上下文時被銷毀, 從而繞過了Nebula3的引用計數生命周期 管理)
  • RefCounted的派生類只有一個默認的構造函數.
  • RefCounted的派生類必須有一個虛析構函數.
  • RefCounted的派生類不能進行拷貝, 因為這樣會造成引用計數機制混亂.

要使用Nebula3的對象模型特性, 除了需要從Core::RefCounted繼承外, 還需要在頭文件新類的聲明中進行額外的標注:

一個標準的RefCounted派生類一般這樣聲明:

1: namespace MyNamespace

2: {

3: class MyClass : public Core::RefCounted

4: {

5: DeclareClass(MyClass);

6: public:

7: /// constructor

8:     MyClass();

9: /// destructor

10: virtual ~MyClass();

11: ...

12: };

13: RegisterClass(MyClass);

注意DeclareClass()宏, 構造函數, 析構函數還有類外面的RegisterClass()宏. DeclareClass()宏加入了RTTI和工廠機制所需的最小代價的信息, 它隱藏了Nebula3的對象模型, 希望可以在不影響已有類的基礎進上進行內部機制的變更. RegisterClass()宏是可選的, 它把當前類在中央工廠進行注冊. 如果你知道這個類永遠不會由類名或四字符編碼進行創建, 這個宏可以省略.

在這個類的.cpp文件里需要包含Nebula3特有的信息:

1: namespace MyNamespace

2: {

3: ImplementClass(MyNamespace::MyClass, 'MYCL', Core::RefCounted);

4:

5: }

ImplementClass()宏注冊類的RTTI機制, 第一個參數描述了類的名字(注意命名空間必須包含). 第二個參數是類的四字符編碼, 它必須是所有類中唯一的(如果有重復, 你會在啟動程序時得到一個錯誤提示). 第三個參數是父類的名字, 用于RTTI系統去構造類的關系樹.

引用計數和智能指針

Nebula3使用傳統的引用計數來管理對象的生命周期. 一個模板智能指針類Ptr<>對程序員隱藏了引用計數的實現細節. 一般來說, 應該一直使用智能指針指向RefCounted的派生對象, 除非你能肯定在給出的代碼塊中這個對象的引用計數不會發生變化.

智能指針相對于一般指針有很多好處:

  • 訪問一個空指針會給你一個斷言警告而不是一個內存錯誤
  • 你不需要對引用計數的對象調用AddRef()或Release() (事實上如果你調了, 會了發生嚴重的錯誤)
  • 智能指針可以在容器類里良好地工作, 一個智能指針的數組會消除所有的一般指針需要的生命周期管理, 你永遠不需要考慮去釋放指針所指針的對象, 數組包含的像是真正的C++對象一樣
  • 用智能指針不需要考慮指針的所屬, 不需要為誰delete對象而煩惱

智能指針也有一些缺點:

  • 性能: 拷貝和賦值會引起對象的引用計數的變化, 解除引用會引起指針的斷言檢查. 這導致的性能消耗一般是可以忽略的, 但是你最好保證它不在內部循環中發生.
  • 應該銷毀的對象還存在: 因為智能指針管理的對象只有在最后一個引用放棄時才會銷毀, 這樣會使對象存在超過預訂的時間. 這經常會導致一個BUG的產生. 不過引用計數泄露(程序退出時還仍然存在的對象)時Nebula3會提醒你.

創建Nebula3對象

從Core::RefCounted繼承的類可以通過3種不同的方式進行創建:

直接通過靜態的Create方法:

1: Ptr<MyClass> myObj = MyClass::Create();

靜態的Create()方法是之前提到的DeclareClass()宏加入的, 相對于new操作符來說, 它并沒有多做什么. 注意正確使用智能指針來保存新建的對象.

另一種創建方式是通過類名:

1: using namespace Core;

2: Ptr<MyClass> myObj = (MyClass*)Factory::Instance()->Create("MyNamespace::MyClass");

當你在運行時通過類名來創建十分有用, 特別是對象的反序列化和腳本接口的使用. 注意類型轉換是必須的, 因為工廠的Creat()方法返回的是RefCounted指針.

由類名創建的變種是根據四字符編碼進行創建:

1: using namespace Core;

2: using namespace Util;

3: Ptr<MyClass> myObj = (MyClass*) Factory::Instance()->Create(FourCC('MYCL'));

這個方法看上去沒有那個直觀, 但是它比類名創建快得多. 并且四字符編碼比類名占用的空間更少, 這更利于對象寫入二進制流或從中讀取.

運行時類型信息系統

Nebula3的RTTI系統可以讓你在運行時訪問對象的類型, 檢查一個對象是不是某個類的實例, 或者某個派生類的實例. 你也可以直接獲得一個對象的類名和四字符編碼. 所有這些功能是由DeclareClass() 和 ImplementClass() 宏在背后實現的.

這時有示例程序:

1:     using namespace Util;

2:     using namespace Core;

3:

4: // check whether an object is instance of a specific class

5: if (myObj->IsInstanceOf(MyClass::RTTI))

6: {

7: // it's a MyClass object

8: }

9:

10: // check whether an object is instance of a derived class

11: if (myObj->IsA(RefCounted::RTTI))

12: {

13: // it's a RefCounted instance or some RefCounted-derived instance

14: }

15:

16: // get the class name of my object, this yields "MyNamespace::MyClass"

17: const String& className = myObj->GetClassName();

18:

19: // get the fourcc class identifier of my object, this yields 'MYCL'

20: const FourCC& fourcc = myObj->GetClassFourCC();

你也可以向中央工廠查詢一個類是否已經注冊:

1:     using namespace Core;

2:

3: // check if a class has been registered by class name

4: if (Factory::Instance()->ClassExists("MyNamespace::MyClass"))

5: {

6: // yep, the class exists

7: }

8:

9: // check if a class has been registered by class fourcc code

10: if (Factory::Instance()->ClassExists(FourCC('MYCL')))

11: {

12: // yep, the class exists

13: }

Nebula3單件

很多Nebula3的核心對象都是單件, 就是只存在一個實例, 并且所有其它對象都知道它.

你可以通過靜態方法Instance()來訪問單件, 它返回唯一實例的一個指針. 返回的指針保證是合法的. 如果在調用Instance()方法時對象實例不存在, 一個斷點會被拋出:

1: // obtain a pointer to the Core::Server singleton

2:     Ptr<Core::Server> coreServer = Core::Server::Instance();

你也可以檢查單件是否存在:

1: // does the Core::Server object exist?

2: if (Core::Server::HasInstance())

3: {

4: // yep, the core server exists

5: }

Nebula3提供了一些輔助的宏來實現單件:

1: // declare a singleton class

2: class MySingletonClass : public Core::RefCounted

3: {

4: DeclareClass(MySingletonClass);

5: DeclareSingleton(MySingletonClass);

6: public:

7: /// constructor

8:     MySingletonClass();

9: /// destructor

10: virtual ~MySingletonClass();

11: ...

12: };

13:

14: // implement the singleton class

15: ImplementClass(MyNamespace::MySingletonClass, 'MYSC', Core::RefCounted);

16: ImplementSingleton(MyNamespace::MySingletonClass);

17:

18: //------------------------------------------------------------------------------

19: /**

20:     Implements the Singleton constructor.

21: */

22: MySingletonClass::MySingletonClass()

23: {

24: ConstructSingleton;

25: }

26:

27: //------------------------------------------------------------------------------

28: /**

29:     Implements the Singleton destructor.

30: */

31: MySingletonClass:~MySingletonClass()

32: {

33: DestructSingleton;

34: }

DeclareSingleton()和ImplementSingleton()宏跟DeclareClass()和ImplementClass()宏差不多.它們在類中添加了一些靜態方法(也就是Instance()和HasInstance()). 類的構造函數和析構函數必須包含ConstructSingletonDestructSingleton宏. ContructSingleton初始化了一個私有的單件指針并保證沒有其它的類實例存在(如果不是, 會拋出斷言). DestructSingleton讓私有的單件指針無效化.

單件的訪問默認是只有本地線程. 這意味著在一個線程中創建的單件無法被其他線程訪問. 這使得”并行Nebula”大大簡化了多線程編程. “并行Nebula”的基本思想是, 一個典型的Nebula3應用程序包含一些”Fat線程”, 每一個Fat線程都是運行在一個單獨的CPU核心上. Fat線程可以用于實現異步IO, 渲染, 物理等等. 每一個Fat線程都初始化了它們自己的Nebula3運行環境, 它們執行特性任務所需的最少依賴. 這基本上消除了大部分Nebula3代碼的同步問題, 并且把線程相關的代碼集中到一個明確定義的代碼區域中. “并行Nebula”的另一個好處就是, 程序員在多線程環境中編程時不需要關心太多. 大多數Nebula3代碼看起來就像單線程代碼一樣, 但是它們卻運行在各自的Fat線程中.

性能與內存占用的考慮

Nebula3核心層的一個設計目標就是減少底層代碼的內存占用, 來更好的適應微型平臺, 像手持設備. 這里有一些已經完成的目標:

  • RefCounted 類在每個實例中只增加了4byte用于引用計數.
  • RTTI機制在開頭增加了30 到 60 byte, 但是這是對于每個類來說的, 而是不是每個實例.
  • 一個智能指針僅僅4 byte, 就像普通指針一樣.
  • 一些監控結構只會在debug模型下創建, 特別是用來檢測引擎計數泄露的RefCountedList.

這里一些用三種不種的創建方法創建一百萬個RefCounted 對象所需的時間信息. 這些時間信息是在臺Intel Pentium 800 MHz的筆記本上得出的.  

  • Create(): 0.29 seconds
  • FourCC: 0.65 seconds
  • 類名: 1.45 seconds

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            久久综合色天天久久综合图片| 亚洲国产精品www| 日韩视频在线观看国产| 欧美mv日韩mv国产网站app| 亚洲欧洲精品一区二区三区波多野1战4| 欧美 日韩 国产精品免费观看| 久久久蜜臀国产一区二区| 亚洲国产精品精华液网站| 亚洲国产高清自拍| 欧美日韩国产综合新一区| 午夜精品久久久久| 欧美在线观看网站| 亚洲日本国产| 亚洲一区二区免费看| 韩国在线视频一区| 亚洲人成小说网站色在线| 国产精品区二区三区日本| 久久女同互慰一区二区三区| 欧美电影免费观看高清| 亚洲欧美在线播放| 久久亚洲私人国产精品va| 亚洲私人影院| 久久视频在线视频| 午夜精品一区二区三区电影天堂 | 久久久亚洲午夜电影| 美国三级日本三级久久99| 亚洲调教视频在线观看| 欧美专区福利在线| 日韩午夜在线| 久久精品成人| 亚洲男人的天堂在线aⅴ视频| 久久久精品999| 亚洲在线第一页| 美女脱光内衣内裤视频久久影院 | 日韩香蕉视频| 香蕉久久夜色精品| 亚洲视频免费在线观看| 久久久久国内| 欧美影院一区| 欧美日韩视频在线第一区| 裸体歌舞表演一区二区| 国产精品区一区二区三| 亚洲激情精品| 亚洲第一区中文99精品| 欧美亚洲一级| 亚洲欧美制服中文字幕| 欧美女激情福利| 欧美电影免费观看大全| 黑人巨大精品欧美一区二区小视频 | 亚洲视频欧美在线| 亚洲国产精品久久人人爱蜜臀| 亚洲精品视频一区| 亚洲激情在线| 美女成人午夜| 美国成人直播| 在线观看的日韩av| 久久精品人人做人人综合| 午夜精品影院| 国产精品看片你懂得| av成人毛片| 一区二区三区产品免费精品久久75| 久久综合九色综合久99| 免费在线观看日韩欧美| 一区二区三区在线免费观看| 久久高清国产| 老司机久久99久久精品播放免费| 国外成人在线| 久久精品欧洲| 欧美不卡福利| 亚洲三级毛片| 欧美日韩国产色站一区二区三区| 亚洲国产高清aⅴ视频| 亚洲国产一区二区a毛片| 毛片av中文字幕一区二区| 免费成人黄色| 日韩午夜免费视频| 国产精品第一区| 香蕉成人伊视频在线观看| 欧美一区二区在线| 极品少妇一区二区三区精品视频| 久久久久9999亚洲精品| 欧美大片专区| 亚洲一区二区欧美日韩| 国产日韩精品电影| 久久欧美肥婆一二区| 亚洲电影一级黄| 亚洲一区一卡| 国内久久婷婷综合| 欧美激情视频在线播放| 中文av字幕一区| 久久久欧美一区二区| 亚洲人成网站999久久久综合| 欧美精品久久天天躁| 亚洲欧美日韩国产中文在线| 玖玖视频精品| 一二三四社区欧美黄| 国产精品影院在线观看| 猫咪成人在线观看| 亚洲主播在线| 欧美激情精品久久久六区热门 | 男人的天堂亚洲| 中文久久乱码一区二区| 国产日韩欧美中文在线播放| 久久亚洲高清| 亚洲五月婷婷| 欧美国产日韩在线观看| 欧美一级片久久久久久久| 亚洲国产一区二区三区高清| 国产精品亚洲第一区在线暖暖韩国| 久久久国产精品一区二区三区| 亚洲精品国产精品乱码不99按摩 | 久久亚裔精品欧美| 一区二区欧美在线| 在线观看一区二区视频| 国产精品五区| 欧美精品在线视频| 久久久久88色偷偷免费| 亚洲一二三四区| 亚洲美女av电影| 欧美电影免费观看高清完整版 | 伊人精品在线| 国产欧美日韩一区二区三区| 欧美精品一区在线播放| 久久日韩精品| 久久久久久久久蜜桃| 亚洲一区二区在线免费观看视频 | 亚洲第一在线视频| 另类av导航| 久久久视频精品| 久久精品国语| 久久精品二区| 小嫩嫩精品导航| 午夜日韩av| 亚洲综合色婷婷| 亚洲一区三区视频在线观看| 99精品黄色片免费大全| 亚洲久久成人| 亚洲伦理在线免费看| 亚洲日本理论电影| 亚洲精品社区| 亚洲美女黄网| 一区二区三区四区国产| 一本色道久久| 亚洲制服av| 亚洲欧美国产毛片在线| 午夜日韩视频| 久久aⅴ国产紧身牛仔裤| 久久xxxx精品视频| 久久精品一区二区三区不卡| 久久精品视频va| 久久躁狠狠躁夜夜爽| 蜜臀av在线播放一区二区三区| 麻豆成人在线| 亚洲国产欧美日韩| 夜夜嗨av一区二区三区网站四季av| 亚洲精品网址在线观看| 亚洲视频在线观看视频| 午夜精品久久久久久久99水蜜桃 | 欧美人与禽性xxxxx杂性| 欧美日韩福利| 国产精品亚洲第一区在线暖暖韩国| 国产伦精品一区二区| 国内成人精品视频| 亚洲国产91精品在线观看| 亚洲靠逼com| 午夜在线a亚洲v天堂网2018| 久久久xxx| 亚洲国产精品久久久久秋霞蜜臀 | 久久精品麻豆| 欧美成人首页| 国产精品久久久免费| 精品1区2区3区4区| 亚洲精品欧美专区| 亚洲欧美视频一区| 久久久综合网| 亚洲区一区二区三区| 亚洲影音先锋| 欧美超级免费视 在线| 国产精品久久久久久av下载红粉| 国产一区二区精品久久| 亚洲精品久久久蜜桃| 欧美在线二区| 亚洲啪啪91| 久久国产欧美精品| 欧美日韩福利| 亚洲国产精品美女| 午夜一区二区三视频在线观看| 免费国产一区二区| 亚洲一区二区视频| 欧美成人首页| 狠狠色狠狠色综合| 亚洲欧美激情在线视频| 亚洲福利在线观看| 欧美一区二区三区久久精品茉莉花| 欧美成人精品一区| 在线观看一区二区视频| 欧美一区二区三区视频免费播放| 亚洲国产精品va| 久久免费视频一区| 国产日本欧美视频|