QObject在QT中是所有类的基类,经过MOC处理后代码如下

之所以贴出这段代码,是因为很多流程追踪到最后一些关键性函数都是出自这个类

源码 4.8.6 MOC版本 63

  1 /****************************************************************************
2 ** Meta object code from reading C++ file 'qobject.h'
3 **
4 ** Created by: The Qt Meta Object Compiler version 63 (Qt 4.8.6)
5 **
6 ** WARNING! All changes made in this file will be lost!
7 *****************************************************************************/
8
9 #include "qobject.h"
10 #if !defined(Q_MOC_OUTPUT_REVISION)
11 #error "The header file 'qobject.h' doesn't include <QObject>."
12 #elif Q_MOC_OUTPUT_REVISION != 63
13 #error "This file was generated using the moc from 4.8.6. It"
14 #error "cannot be used with the include files from this version of Qt."
15 #error "(The moc has changed too much.)"
16 #endif
17
18 QT_BEGIN_MOC_NAMESPACE
19 static const uint qt_meta_data_QObject[] = {
20
21 // content:
22 6, // revision
23 0, // classname
24 0, 0, // classinfo
25 4, 14, // methods
26 1, 34, // properties
27 0, 0, // enums/sets
28 2, 37, // constructors
29 0, // flags
30 2, // signalCount
31
32 // signals: signature, parameters, type, tag, flags
33 9, 8, 8, 8, 0x05,
34 29, 8, 8, 8, 0x25,
35
36 // slots: signature, parameters, type, tag, flags
37 41, 8, 8, 8, 0x0a,
38 55, 8, 8, 8, 0x08,
39
40 // properties: name, type, flags
41 90, 82, 0x0a095103,
42
43 // constructors: signature, parameters, type, tag, flags
44 108, 101, 8, 8, 0x0e,
45 126, 8, 8, 8, 0x2e,
46
47 0 // eod
48 };
49
50 static const char qt_meta_stringdata_QObject[] = {
51 "QObject\0\0destroyed(QObject*)\0destroyed()\0"
52 "deleteLater()\0_q_reregisterTimers(void*)\0"
53 "QString\0objectName\0parent\0QObject(QObject*)\0"
54 "QObject()\0"
55 };
56
57 void QObject::qt_static_metacall(QObject *_o, QMetaObject::Call _c, int _id, void **_a)
58 {
59 if (_c == QMetaObject::CreateInstance) {
60 switch (_id) {
61 case 0: { QObject *_r = new QObject((*reinterpret_cast< QObject*(*)>(_a[1])));
62 if (_a[0]) *reinterpret_cast<QObject**>(_a[0]) = _r; } break;
63 case 1: { QObject *_r = new QObject();
64 if (_a[0]) *reinterpret_cast<QObject**>(_a[0]) = _r; } break;
65 }
66 } else if (_c == QMetaObject::InvokeMetaMethod) {
67 Q_ASSERT(staticMetaObject.cast(_o));
68 QObject *_t = static_cast<QObject *>(_o);
69 switch (_id) {
70 case 0: _t->destroyed((*reinterpret_cast< QObject*(*)>(_a[1]))); break;
71 case 1: _t->destroyed(); break;
72 case 2: _t->deleteLater(); break;
73 case 3: _t->d_func()->_q_reregisterTimers((*reinterpret_cast< void*(*)>(_a[1]))); break;
74 default: ;
75 }
76 }
77 }
78
79 const QMetaObjectExtraData QObject::staticMetaObjectExtraData = {
80 0, qt_static_metacall
81 };
82
83 const QMetaObject QObject::staticMetaObject = {
84 { 0, qt_meta_stringdata_QObject,
85 qt_meta_data_QObject, &staticMetaObjectExtraData }
86 };
87
88 #ifdef Q_NO_DATA_RELOCATION
89 const QMetaObject &QObject::getStaticMetaObject() { return staticMetaObject; }
90 #endif //Q_NO_DATA_RELOCATION
91
92 const QMetaObject *QObject::metaObject() const
93 {
94 return QObject::d_ptr->metaObject ? QObject::d_ptr->metaObject : &staticMetaObject;
95 }
96
97 void *QObject::qt_metacast(const char *_clname)
98 {
99 if (!_clname) return 0;
100 if (!strcmp(_clname, qt_meta_stringdata_QObject))
101 return static_cast<void*>(const_cast< QObject*>(this));
102 return 0;
103 }
104
105 int QObject::qt_metacall(QMetaObject::Call _c, int _id, void **_a)
106 {
107 if (_id < 0)
108 return _id;
109 if (_c == QMetaObject::InvokeMetaMethod) {
110 if (_id < 4)
111 qt_static_metacall(this, _c, _id, _a);
112 _id -= 4;
113 }
114 #ifndef QT_NO_PROPERTIES
115 else if (_c == QMetaObject::ReadProperty) {
116 void *_v = _a[0];
117 switch (_id) {
118 case 0: *reinterpret_cast< QString*>(_v) = objectName(); break;
119 }
120 _id -= 1;
121 } else if (_c == QMetaObject::WriteProperty) {
122 void *_v = _a[0];
123 switch (_id) {
124 case 0: setObjectName(*reinterpret_cast< QString*>(_v)); break;
125 }
126 _id -= 1;
127 } else if (_c == QMetaObject::ResetProperty) {
128 _id -= 1;
129 } else if (_c == QMetaObject::QueryPropertyDesignable) {
130 _id -= 1;
131 } else if (_c == QMetaObject::QueryPropertyScriptable) {
132 _id -= 1;
133 } else if (_c == QMetaObject::QueryPropertyStored) {
134 _id -= 1;
135 } else if (_c == QMetaObject::QueryPropertyEditable) {
136 _id -= 1;
137 } else if (_c == QMetaObject::QueryPropertyUser) {
138 _id -= 1;
139 }
140 #endif // QT_NO_PROPERTIES
141 return _id;
142 }
143
144 // SIGNAL 0
145 void QObject::destroyed(QObject * _t1)
146 {
147 void *_a[] = { 0, const_cast<void*>(reinterpret_cast<const void*>(&_t1)) };
148 QMetaObject::activate(this, &staticMetaObject, 0, _a);
149 }
150 QT_END_MOC_NAMESPACE

仅供参考,做一些深层次的分析

转自:http://www.cnblogs.com/lfsblack/p/5319437.html

8、QObject类 moc处理后代码的更多相关文章

  1. QObject类 moc处理后代码

    QObject在QT中是所有类的基类,经过MOC处理后代码如下 之所以贴出这段代码,是因为很多流程追踪到最后一些关键性函数都是出自这个类 源码 4.8.6 MOC版本 63 /************ ...

  2. JD-GUI反编译后代码逻辑分析

    一,用jd-gui.exe等工具查看源代码.如何你不会,可以参看此文章: http://blog.csdn.net/hp_2008/article/details/8207879 可以到以下连接下载可 ...

  3. [置顶] NS2中对TCP数据包和ACK包的TCP Sink类的主要实现代码详尽剖析--吐血放送

    NS2中对TCP数据包和ACK包的TCP Sink类的主要实现代码详尽剖析,限于个人水平,如有错误请留言指出! TcpSink类的recv()方法: void TcpSink::recv(Packet ...

  4. 1.QObject类

    简述 QObject类是所有Qt对象的基类. QObject是Qt对象模型的核心. 该模型的核心特征是称为信号和槽的对象通信机制. 您可以使用connect()将信号连接到槽,并用disconnect ...

  5. 关于 QObject 类

    1.QObject类   简述 QObject类是所有Qt对象的基类. QObject是Qt对象模型的核心. 该模型的核心特征是称为信号和槽的对象通信机制. 您可以使用connect()将信号连接到槽 ...

  6. C++派生类中如何初始化基类对象(五段代码)

    今天收到盛大的面试,问我一个问题,关于派生类中如何初始化基类对象,我在想派生类对于构造函数不都是先构造基类对象,然后在构造子类对象,但是如果我们在成员初始化列表先初始化派生类的私有成员,在函数内去调用 ...

  7. Qt::QObject类

    QObject 类是Qt 所有类的基类. QObject是Qt对象模型的核心.这个模型的中心要素就是一种强大的叫做信号与槽无缝对象沟通机制.你可以用 connect()函数来把一个信号连接到槽,也可以 ...

  8. 谈谈Delphi中的类和对象4---类是一种对数据和操作高度的封装机制 && 类是一种代码重用机制

    五.类是一种对数据和操作高度的封装机制 1)数据封装 unit Unit2; interface type TEmployee = class; private FName: String; publ ...

  9. 关于QObject类的一些理解

    QRunnable并没有继承自QObject,所以它和其他QObject组件的通信不能使用传统的信号和槽,要是用信号和槽我们必须将其继承自QObject自动的添加 QThread的退出最好用exit( ...

随机推荐

  1. 帝国cms使用自定义函数获取新闻文章数 实例分享

    原文地址:http://www.jbxue.com/cms/24337.html 介绍了帝国cms系统中通过用户自定义函数获取用户发表新闻数量的方法,主要是分享下帝国cms自定义函数功能. 在帝国cm ...

  2. [svc]centos6使用chkconfig治理服务和其原理

    centos6开机启动级别 $ cat /etc/inittab ... # 0 - halt (Do NOT set initdefault to this) # 1 - Single user m ...

  3. Daemontools和Supervisor管理linux常驻进程

    linux主要使用supervise来管理常驻进程.基于supervise的两个比较重要的工具是Daemontools和Supervisor. 实际上,supervise也算Daemontools的一 ...

  4. rabbitmq 二进制安装

    # wget -Uvh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm # ls epel-rele ...

  5. 【小白的CFD之旅】26 何为收敛

        小白最近对流体计算的收敛产生了困惑.以前在学习高等数学的时候,小白接触过了级数的收敛,由于当时贪玩,并未将其放在心上,因此大学结束了小白也只是记住有这么一个名词罢了.现如今在利用CFD的过程中 ...

  6. OpenStack OVS GRE/VXLAN

    https://www.jianshu.com/p/0b52de73a4b3 OpenStack OVS GRE/VXLAN网络 学习或者使用OpenStack普遍有这样的现象:50%的时间花费在了网 ...

  7. (原创)发布一个c++11开发的轻量级的并行Task库TaskCpp

    TaskCpp简介 TaskCpp是c++11开发的一个跨平台的并行task库,它的设计思路来源于微软的并行计算库ppl和intel的并行计算库tbb,关于ppl和tbb我在前面有介绍.既然已经有了这 ...

  8. tensorflow笔记3:CRF函数:tf.contrib.crf.crf_log_likelihood()

    在分析训练代码的时候,遇到了,tf.contrib.crf.crf_log_likelihood,这个函数,于是想简单理解下: 函数的目的:使用crf 来计算损失,里面用到的优化方法是:最大似然估计 ...

  9. python(49):把文件压缩成zip格式的文件

    有时需要用到压缩文件,网上搜集了一段代码: 分享一下: import os import zipfile def make_zip(localPath, pname): zipf = zipfile. ...

  10. asp.net读取用户控件,自定义加载用户控件

    1.自定义加载用户控件 ceshi.aspx页面 <html> <body> <div id="divControls" runat="se ...