成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

解析 Qt 內省機制

移動開發
Qt 內省機制是本文要介紹的內容,內省是什么?內省是指面向對象語言的一種在運行期間查詢對象信息的能力。先來看本文!

本文介紹的是Qt 內省機制,關于內省,新手的原因,我們一塊學習,所謂內省是指面向對象語言的一種在運行期間查詢對象信息的能力, 比如如果該語具有運行期間檢查對象型別的能力,那么我們稱它是型別內省(type intropection)的,型別內省可以用來實施多態。

c++內省比較有限,它僅支持上面所說的型別內省, C++的型別內省是通過運行時類型識別(RTTI)(Run-Time Type Information)中的typeid 以及 dynamic_case關鍵字來實現的,舉例說明:

  1.     // rabbit 派生于 Animal, jump為虛函數  
  2.  
  3. if ( rabbit *p = dynamic_case<Animal*>(obj))     
  4. {     
  5.    p->jump();     
  6. }     
  7. //我們還可以通過typeid萃取到對象的型別信息,比如對象的名稱   
  8. std::cout << typeid(obj).name() << std::endl   

Qt拓展了C++的內省機制,(實際上,它并沒有采用c++的RTTI),而是提供了更為強大的元對象(meta object)機制,來實現內省。接下來,就讓我們看看,Qt是如何擴展c++內省機制的。

要深刻理解Qt的內省機制,首先理解QObject,QObject類是整個Qt對象模型的心臟,Qt對象模型最為核心的功能是提供一種無縫的對象通訊機制,即就是我們所熟知的信號和槽。QObject主要有三大職責: 內存管理、內省(intropection)與事件處理。本文將集中在在內省的討論。以下代碼介紹了QObject類提供的內省方法: 

  1. //每個對象可以通過QObject::setObjectName()和QObject::objectName()設置、取得類的實例的名字   
  2. FirstQtApp obj;    
  3. obj.setObjectName("instanceName");    
  4. QString name1 = obj.objectName();   // return instanceName   
  5. //每個對象還可以通過它的元對象className方法得到類的名字   
  6. QString name2 = obj.metaObject()->className();  // return FirtstQtApp   
  7. //每個對象可以通過QObject::inherits方法來查詢是否對前對象類派生于量一個類   
  8. bool isherited =  obj.inherits("QObject");         // returns true   
  9. isherited =  obj.inherits("QWideget");         // returns true  

讓我們再來一下QObject::inherits方法的底層實現:

  1. inline bool inherits(const char *classname) const   
  2.     { return const_cast<QObject *>(this)->qt_metacast(classname) != 0; }  

原來,QObject::inherits是通過qt_metacast()這個虛函數實現的, 事實上每個QObject的派生類都必須實現metaObject()以及其他qt_metacall()方法,從而滿足自省方法className, inherits等方法的調用(當然還有其他用途)。

而所有有關派生從QObject的子類中的內省方法無須有用戶實現,用戶只要在類中聲明宏Q_OBJECT即可,Qt的元對象編譯器(moc)負責實現派生從QObject的子類中的內省方法。

  1. // defined at ..\Qt\src\corelib\kernel\qobjectdefs.h   
  2. /* tmake ignore Q_OBJECT */   
  3. #define Q_OBJECT \   
  4. public: \     
  5.     Q_OBJECT_CHECK \     
  6. static const QMetaObject staticMetaObject; \     
  7.     Q_OBJECT_GETSTATICMETAOBJECT \     
  8. virtual const QMetaObject *metaObject() const; \     
  9. virtual void *qt_metacast(const char *); \     
  10.     QT_TR_FUNCTIONS \     
  11. virtual int qt_metacall(QMetaObject::Call, int, void **); \  

此外,所有的Qt widgets類均繼承自QObject, QObject所提供的isWidgetType自省方法可以很方便讓QObject子對象查詢自己是否是wideget, 而且它會比 qobject_cast<QWidget *>(obj) 或者 obj->inherits快很多。原因qobject_cast()t和inherits()都是借助元對象系統來實現其功能的,isWidgetType()是QObject本身的標志位得以實現。

更多自省方法定義在QMetaObject,以下是QMetaObject聲明的源代碼:

  1. struct Q_CORE_EXPORT QMetaObject     
  2. {     
  3. const char *className() const;     
  4. const QMetaObject *superClass() const;     
  5.     QObject *cast(QObject *obj) const;     
  6.  
  7.     ....     
  8. int methodOffset() const;     
  9. int enumeratorOffset() const;     
  10. int propertyOffset() const;     
  11. int classInfoOffset() const;     
  12. int constructorCount() const;     
  13. int methodCount() const;     
  14. int enumeratorCount() const;     
  15. int propertyCount() const;     
  16. int classInfoCount() const;     
  17. int indexOfConstructor(const char *constructor) const;     
  18. int indexOfMethod(const char *method) const;     
  19. int indexOfSignal(const char *signal) const;     
  20. int indexOfSlot(const char *slot) const;     
  21. int indexOfEnumerator(const char *name) const;     
  22. int indexOfProperty(const char *name) const;     
  23. int indexOfClassInfo(const char *name) const;     
  24.     ...     
  25. }   

上述方法主要是實現對元對象表的訪問及其操作,對元對象表(由moc實現)實例如下所示:

  1. // defined at ..\Qt\src\corelib\kernel\qobjectdefs.h   
  2. /* tmake ignore Q_OBJECT */   
  3. #define Q_OBJECT \   
  4. public: \    
  5.     Q_OBJECT_CHECK \    
  6. static const QMetaObject staticMetaObject; \    
  7.     Q_OBJECT_GETSTATICMETAOBJECT \    
  8. virtual const QMetaObject *metaObject() const; \    
  9. virtual void *qt_metacast(const char *); \    
  10.     QT_TR_FUNCTIONS \    
  11. virtual int qt_metacall(QMetaObject::Call, int, void **); \   

總結:

1、Qt是通過QObject、QMetaObject類實現其內省機制,

2、QObject暴露給用戶的共有自省方法有objectName(), inherits(), isWidgetType()等

3、大多數自省方法是QObject派發給QMetaObject實現 (e.g. QMetaObject::className,),元對象模型編譯器moc負責自省方法的實現

4、更多自省方法定義在QMetaObject,而是為了等信號槽通訊、事件派發等機制,

小結:關于解析 Qt 內省機制剖析的內容介紹完了,希望本文對你有所幫助!

責任編輯:zhaolei 來源: 互聯網
相關推薦

2011-08-02 18:07:03

iPhone 內省 Cocoa

2011-06-22 16:50:09

Qt 進程 通信機制

2011-02-28 09:51:43

內省

2009-07-14 18:09:08

Jython的內省

2011-06-23 14:40:13

Qt 信號

2011-06-23 14:05:32

Qt 事件機制

2011-06-09 17:26:17

Qt 插件 API

2011-09-09 17:59:26

QT Widget

2011-06-08 15:27:24

QT QT 4.5 編譯

2011-06-09 15:18:07

QT 編譯

2011-06-09 09:45:35

Linux QT 信號

2011-07-05 18:32:52

QT 信號 機制

2011-06-23 15:32:05

Qt Windows消息

2011-07-05 18:40:19

QT 信號 機制

2011-07-01 14:20:59

Qt 事件

2011-07-01 14:14:34

Qt 事件

2011-06-27 09:15:21

QT Creator

2011-07-01 14:39:08

Qt Quick

2011-06-22 15:50:45

QT 線程

2011-06-29 17:20:20

Qt 內存 QOBJECT
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲免费人成在线视频观看 | 亚洲精品久久久一区二区三区 | 精品国产欧美一区二区 | 中文字幕一区二区三区四区五区 | 成人欧美一区二区三区视频xxx | 九九久久国产精品 | 中文字幕免费中文 | 欧美一级黄 | 色黄视频在线 | 久久一级免费视频 | 神马九九 | 欧美一级免费 | 国产成人免费视频网站视频社区 | 羞羞视频网站 | 久久久久久综合 | 91免费观看 | 九九九国产 | 亚洲日本一区二区三区四区 | 中文在线a在线 | 亚洲一区在线观看视频 | 99久久久99久久国产片鸭王 | 亚洲精品白浆高清久久久久久 | 黄色在线免费观看视频网站 | 一级毛片观看 | av色站 | 婷婷色成人 | 中文字幕日韩专区 | www.日本在线观看 | 精品在线免费观看视频 | 久久美女网 | 国产第1页 | 国产精品99久久久久久www | 亚洲一区二区三区免费视频 | 久久美女网 | 黄色大片免费播放 | 国产丝袜一区二区三区免费视频 | 欧美一区二区三区大片 | 视频1区2区 | 日韩精品免费播放 | 成人在线视频免费观看 | 青草福利 |