• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            天下

            記錄修行的印記

            QT 的信號與槽機制(1)

             

            QT 的信號與槽機制(1)
            信號
            當某個信號對其客戶或所有者發生的內部狀態發生改變,信號被一個對象發射。只有 定義過這個信號的類及其派生類能夠發射這個信號。當一個信號被發射時,與其相關聯的槽將被立刻執行,就象一個正常的函數調用一樣。信號 
            - 槽機制完全獨立于任何 GUI 事件循環。只有當所有的槽返回以后發射函數(emit)才返回。 如果存在多個槽與某個信號相關聯,那么,當這個信號被發射時,這些槽將會一個接一個地 執行,但是它們執行的順序將會是隨機的、不確定的,我們不能人為地指定哪個先執行、哪 個后執行。
            信號的聲明是在頭文件中進行的,QT 的 signals 關鍵字指出進入了信號聲明區,隨后即可 聲明自己的信號。例如,下面定義了三個信號:
            signals: 
            void mySignal(); 
            void mySignal(int x); 
            void mySignalParam(int x,int y);


            在上面的定義中,signals 是 QT 的關鍵字,而非 C/C++ 的。
            接下來的一行 void mySignal() 定義了信號 mySignal,這個信號沒有攜帶參數;
            接下來的一行 void mySignal(int x) 定義 了重名信號 mySignal,但是它攜帶一個整形參數,這有點類似于 C++ 中的虛函數。
            從形式上 講信號的聲明與普通的 C++ 函數是一樣的,但是信號卻沒有函數體定義,另外,信號的返回 類型都是 void,不要指望能從信號返回什么有用信息。
            信號由 moc 自動產生,它們不應該在 .cpp 文件中實現。


            槽是普通的 C++ 成員函數,可以被正常調用,它們唯一的特殊性就是很多信號可以與其相關聯。當與其關聯的信號被發射時,這個槽就會被調用。槽可以有參數,但槽的參數不能有缺省值。
            既然槽是普通的成員函數,因此與其它的函數一樣,它們也有存取權限。槽的存取權限決定了誰能夠與其相關聯。同普通的 C
            ++ 成員函數一樣,槽函數也分為三種類型,即 public slots、private slots 和 protected slots。
            public slots:在這個區內聲明的槽意味著任何對象都可將信號與之相連接。這對于組件編程非常有用,你可以創建彼此互不了解的對象,將它們的信號與槽進行連接以便信息能夠正確的傳遞。
            protected slots:在這個區內聲明的槽意味著當前類及其子類可以將信號與之相連接。這適用于那些槽,它們是類實現的一部分,但是其界面接口卻面向外部。
            private slots:在這個區內聲明的槽意味著只有類自己可以將信號與之相連接。這適用于聯系非常緊密的類。
            槽也能夠聲明為虛函數,這也是非常有用的。
            槽的聲明也是在頭文件中進行的。例如,下面聲明了三個槽:
            public slots: 
                
            void mySlot(); 
                
            void mySlot(int x); 
                
            void mySignalParam(int x,int y);
                
                
            信號與槽的關聯
            通過調用 QObject 對象的 connect 函數來將某個對象的信號與另外一個對象的槽函數相關聯,這樣當發射者發射信號時,接收者的槽函數將被調用。該函數的定義如下:
            static bool QObject::connect(const QObject *sender, const char *signal,const QObject *receiver, const char *method,Qt::ConnectionType type)


                                  
            用信號signals和槽slots需注意的基本問題是:
            在所有包含signal與slot的類的聲明中:
            1)在類class聲明中必須加入Q_OBJECT
            2)類的聲明文件必須成單獨保存一個到.h文件

             

            posted on 2012-08-24 15:41 天下 閱讀(436) 評論(0)  編輯 收藏 引用 所屬分類: QT

            <2012年4月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            香蕉99久久国产综合精品宅男自 | 国内精品伊人久久久久av一坑| 91麻豆国产精品91久久久| 日本五月天婷久久网站| 日韩久久久久久中文人妻| 久久福利青草精品资源站| 久久人人爽人爽人人爽av| 亚洲国产精品久久久天堂| 日韩亚洲欧美久久久www综合网 | 2021最新久久久视精品爱| 久久91亚洲人成电影网站| 久久青青草原精品国产不卡| 久久人人爽爽爽人久久久| 国产精品无码久久综合网| 日韩人妻无码精品久久免费一| 国产国产成人久久精品| 久久久噜噜噜久久熟女AA片| 久久久久久一区国产精品| 奇米综合四色77777久久| 人人狠狠综合久久亚洲| 人人狠狠综合久久亚洲婷婷| 性高湖久久久久久久久| 午夜精品久久久久久久无码| 亚洲国产精品婷婷久久| 久久婷婷五月综合色奶水99啪| 亚洲国产精品狼友中文久久久| 91久久精品国产成人久久| 东京热TOKYO综合久久精品| 精品熟女少妇AV免费久久| 蜜臀久久99精品久久久久久| 久久精品国产91久久麻豆自制| 久久久女人与动物群交毛片 | 亚洲精品无码久久一线| 麻豆久久久9性大片| 日日狠狠久久偷偷色综合0| 久久精品国产精品亚洲艾草网美妙| 久久精品国产一区| 99久久国产综合精品成人影院| 久久精品九九亚洲精品天堂| 亚洲一区中文字幕久久| 91久久香蕉国产熟女线看|