Qt 編程點(diǎn)滴 初學(xué)者必看 (9)
Qt 編程繼續(xù)為大家講解,還是接著文章 Qt 編程點(diǎn)滴 初學(xué)者必看 (8) ,繼續(xù)介紹,說(shuō)編程那些細(xì)節(jié)。由于本話題是一節(jié)一節(jié)為大家介紹的,所以更多內(nèi)容請(qǐng)看末尾編輯推薦。
QString怎么轉(zhuǎn)換成char
- QString str ="123456";
- str.toAscii().data(); //this return a char* or const char*
- str.toAscii() return a QByteArray
- QString Str; //Str = "asdfasdfasdf";
- Str->toString().c_str();
調(diào)用 Q_DECLARE_METATYPE 報(bào)以下錯(cuò)
- ..\..\..\..\Qt\src\corelib\kernel\qmetatype.h||In function \\\'void* qMetaTypeConstructHelper(const T*) [with T = ContactsInfoTabItemData]\\\':|
- ..\..\..\..\Qt\src\corelib\kernel\qmetatype.h|152|instantiated from \\\'int qRegisterMetaType(const char*, T*) [with T = ContactsInfoTabItemData]\\\'|
- src\contactsinfotabitemdata.h|62|instantiated from here|
- ..\..\..\..\Qt\src\corelib\kernel\qmetatype.h|126|error: no matching function for call to \\\'ContactsInfoTabItemData::ContactsInfoTabItemData()\\\'|
如果報(bào)以上相類似的錯(cuò)誤,請(qǐng)對(duì)構(gòu)造函數(shù)中的每個(gè)參數(shù)賦初值,下面的寫法是錯(cuò)誤的
- class ContactsInfoTabItemData
- {
- public:
- ContactsInfoTabItemData(QString name,QString caption);
- };
- Q_DECLARE_METATYPE(ContactsInfoTabItemData);
正確的寫法應(yīng)為:
- class ContactsInfoTabItemData
- {
- public:
- ContactsInfoTabItemData(QString name=QString(),QString caption=QString());
- };
- Q_DECLARE_METATYPE(ContactsInfoTabItemData);
如果程序莫名奇妙的退出,也不報(bào)DLL找不到的錯(cuò)誤,請(qǐng)仔細(xì)檢查Main函數(shù)體有沒(méi)直接Return的語(yǔ)句,以造成不提示,直接退出的錯(cuò)誤;
在Qt中計(jì)算文本的寬度與高度 ( http://www.cuteqt.com/blog/?p=1029 )
- error: incomplete type %u2018nsIDOMComment%u2019 used in nested name specifier
產(chǎn)生此錯(cuò)誤的原因:
- g++ gives this message if you\\\'ve forward-declared a type, like this
- class MyClass;
- and then you try and access one of its members, like maybe:
- MyClass::doSomething()
- g++ is complaining that it hasn\\\'t seen the body of class MyClass yet, so it has no way to know what MyClass::doSomething is.
- (In C++ jargon, an "incomplete type" is a type that\\\'s been forward-declared but not yet defined.)
互斥用法:
- QMutex mutex;
- void GlobalVar::setUserInfo(const GlobalVar::UserInfo &userInfo)
- {
- QMutexLocker locker(&mutex);
- this->userinfo = userInfo;
- }
自定義事件方法:
- a.h:
- #include "event.h"
- typedef void ( EventDelegater::*SetWidgetParent )(QWidget*,QString );
- class test
- {
- public:
- Event OnSetWidgetParent;
- private:
- inline void invokeSetWidgetParent(QWidget *parentWidget,QString widgetName);
- };
- a.cpp:
- inline void test::invokeSetWidgetParent(QWidget *parentWidget,QString widgetName)
- {
- if ( !OnSetWidgetParent.m_EventList.empty() )
- {
- // 循環(huán)事件列表
- Event< SetWidgetParent >::EventIterator iter;
- for ( iter = OnSetWidgetParent.m_EventList.begin();
- iter != OnSetWidgetParent.m_EventList.end();
- ++iter )
- {
- // 調(diào)用事件
- InvokeEvent( parentWidget, widgetName );
- }
- }
- }
觸發(fā)事件:
- invokeSetWidgetParent(NULL,QString());
綁定事件方法:
- test->OnSetWidgetParent.Bind(this, &MainWindow::setWidgetParent);
自定義宏的用法:
- *.pro
- DEBUGSAVETOFILE = 1
- isEmpty(DEBUGSAVETOFILE){
- win32:debug {
- CONFIG += console
- }
- }
- else{
- DEFINES += __DEBUGSAVETOFILE__
- }
- main.cpp:
- #ifdef __DEBUGSAVETOFILE__
- #pragma message( "__DEBUGSAVETOFILE__ is defined.")
- qInstallMsgHandler( messageOutput );
- #else
- #pragma message("win32:debug is defined.")
- #endif
小結(jié):本文主要介紹了在Qt 事件的使用,通過(guò)Qt 編程點(diǎn)滴介紹,也給自己提高了編程過(guò)程中需要注意的細(xì)節(jié)問(wèn)題,由于本話題是一節(jié)一節(jié)為大家展現(xiàn)的,所以更多內(nèi)容,請(qǐng)看編輯推薦。