1、需要繼承qobject 。
2、需要有q_object巨集。
3、如果有多重的繼承關係,則每個子類都需要單獨寫q_object巨集,不能因為父類有q_object巨集就省略。
4、繼承qobject的類的宣告必須在.**件中,否則無法產生moc檔案,訊號和槽的鏈結就不起作用。
1 class myclass : publicqobject2
6 }5、訊號和槽的鏈結用 connect函式。
//!舊鏈結方式 編譯時不檢查(物件,槽,訊號)存在與否,不做隱式轉換,錯誤只能再執行時發現。
connect( &mtcpserver, signal(newconnection()), piointf, slot(test()) );//!新鏈結方式 編譯時會檢查,引數會做隱式轉換。
qobject::connect( &mtcpserver, &qtcpserver::newconnection, piointf, &csocketinte***ce::test );
6、connect的第五個引數有以下幾個選項,這裡對五個引數的說明參考的 的帖子。
特別注意的是:平時使用connect函式,如果不指定第五個引數,則預設是qt::autoconnection, 一定要檢查發射訊號的物件與槽函式所在的物件是否在同乙個執行緒。
1、如果在同乙個執行緒,則預設是直接呼叫的方式,一般沒什麼問題。
2、如果不在同乙個執行緒,則預設使用佇列非同步呼叫的方式,如果兩個執行緒都不會被挪動,那一般也沒什麼問題。
3、如果不在同乙個執行緒,且這兩個執行緒在程式執行期間會被挪動,那就會出現訊號傳送出去,槽函式沒反應的現象,而且一般還不太好找原因, 如果出現這種問題,可視情況指定qt::directconnection引數,採用直接呼叫的方式解決。
qt::directconnection //直接連線意味著槽函式將在訊號發出的執行緒直接呼叫
Qt訊號和槽
qt將訊號和槽關聯起來的connect使用時需要注意帶相應的引數,否則會出現訊號發出後不能呼叫槽的問題,例子如下 發出訊號的宣告 signals void receiveddata uchar dat,uint len 接收訊號的槽宣告 private slots void getdata ucha...
Qt 訊號和槽
函式原型 qobject connect const qobject sender,const char signal,const qobject receiver,const char method,qt connectiontype type qt autoconnection 通常使用的con...
QT訊號和槽
qt訊號和槽 訊號和槽是一種高階介面,應用於物件之間的通訊,它是 qt 的核心特性。要正確的處理訊號和槽,必須借助乙個稱為 moc meta object compiler 的 qt 工具,該工具是乙個 c 預處理程式,它為高層次的事件處理自動生成所需要的附加 訊號和槽能攜帶任意數量和任意型別的引數...