qmoc文件_Qt中Q_OBJECT与生成的moc文件的作用
Qt中Q_OBJECT與生成的moc文件的作用
一、先來了解Q_OBJECT
只有繼承了QObject類的類,才具有信號槽的能力。所以,為了使用信號槽,必須繼承QObject。凡是QObject類(不管是直接子類還是間接子類),都應(yīng)該在第一行代碼寫上Q_OBJECT。不管是不是使用信號槽,都應(yīng)該添加這個宏。這個宏的展開將為我們的類提供信號槽機(jī)制、國際化機(jī)制以及 Qt 提供的不基于 C++ RTTI 的反射能力。因此,如果你覺得你的類不需要使用信號槽,就不添加這個宏,就是錯誤的。其它很多操作都會依賴于這個宏。
注意:由于 moc 只處理頭文件中的標(biāo)記了Q_OBJECT的類聲明,不會處理 cpp 文件中的類似聲明(這個不信的同學(xué)私下可以試下去掉Q_OBJECT看信號槽還能正常連接?)。因此,如果我們的類位于 main.cpp 中,是無法得到 moc 的處理的。解決方法是,我們手動調(diào)用 moc 工具處理 main.cpp,并且將 main.cpp 中的#include “xxx.h”改為#include “moc_xxx.h”就可以了。不過,這是相當(dāng)繁瑣的步驟,為了避免這樣修改,我們還是將其放在頭文件中。許多初學(xué)者會遇到莫名其妙的錯誤,一加上Q_OBJECT就出錯,很大一部分是因為沒有注意到這個宏應(yīng)該放在頭文件中
二、moc_class作用
Qt 將源代碼交給標(biāo)準(zhǔn) C++ 編譯器,如 gcc 之前,需要事先將這些擴(kuò)展的語法去除掉。完成這一操作的就是 moc。
moc 全稱是 Meta-Object Compiler,也就是“元對象編譯器”。Qt 程序在交由標(biāo)準(zhǔn)編譯器編譯之前,先要使用 moc 分析 C++ 源文件。如果它發(fā)現(xiàn)在一個頭文件中包含了宏 Q_OBJECT,則會生成另外一個 C++ 源文件。這個源文件中包含了 Q_OBJECT 宏的實現(xiàn)代碼。這個新的文件名字將會是原文件名前面加上 moc_ 構(gòu)成。這個新的文件同樣將進(jìn)入編譯系統(tǒng),最終被鏈接到二進(jìn)制代碼中去。因此我們可以知道,這個新的文件不是“替換”掉舊的文件,而是與原文件一起參與編譯。另外,我們還可以看出一點,moc 的執(zhí)行是在預(yù)處理器之前。因為預(yù)處理器執(zhí)行之后,Q_OBJECT 宏就不存在了。
在命令行下輸入moc yourfilename.h -o moc_youfilename.cpp生成不帶Q_OBJENT的源文件
總結(jié)起來就是:
moc 就是“元對象編譯器”;
Qt程序在交給標(biāo)準(zhǔn)編譯器預(yù)編譯之前要使用 moc 分析 C++ 源文件;
如果有宏 Q_OBJECT,則生成一個包含Q_OBJECT 宏的實現(xiàn)代碼的C++源文件;
新生成的源文件參與到標(biāo)準(zhǔn)編譯器的編譯中;
編譯過程中如果找不到對應(yīng)的moc文件就會出現(xiàn)鏈接錯誤,此時要添加上對應(yīng)的moc文件;
遇到的問題:
1.? error PRJ0019: A tool returned an error code from "Moc'ing treenodepreferencepage.h..." imediago
1)主要是.h文件的屬性配置有問題,詳細(xì)解決方案參見下面鏈接;
https://jingyan.baidu.com/article/3065b3b68518adbecef8a477.html
有時候簡單的修改這個屬性還不能起到想要的效果,具體原因以及應(yīng)對方法等到下周一分解
2)有可能是定義的類沒有繼承QObject這樣的Qt類導(dǎo)致的;
================== End
總結(jié)
以上是生活随笔為你收集整理的qmoc文件_Qt中Q_OBJECT与生成的moc文件的作用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: array_uniquee php_【性
- 下一篇: 电脑系统玩英雄联盟蓝屏怎么解决办法 电脑