• <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>

            牽著老婆滿街逛

            嚴以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            libjingle翻譯之《Important Concepts(重要概念)之Signals (信號)》

            轉載自:http://blog.csdn.net/night_cat/article/details/3495530

            Important Concepts(重要概念)

            你應該理解libjingle中以下的重要概念:

             Signals                                          (信號)

             Threads and Messages                     (線程、消息)

             Naming Conventions                        (命名約定)

             SSL Support                                    SSL 支持)

             Connections                                    (鏈接)

             Transports, Channels, and Connections (傳輸、通道、鏈接)

             Candidates                                     (協商)

             Data Packets                                   (數據包)

             

             

            Signals   (信號)

            libjingle 使用sigslot 促進對象間的通信。sigslot是一種framework,它可以把呼叫方(calling member)和任意類實現的接收函數很容易地關聯起來,工作方式就像這樣:

            1、  發出呼叫的類聲明一個數據成員(被稱作信號),聲明方式使用一種很像模板的語法。這個信號數據成員定義了和接收函數一致的參數。(注:這個接收函數當然是屬于某個類了)

            2、  類中的接收函數在實現時,它的參數必須與它關聯的信號的參數相同,這里的參數相同是指數量相同,類型相同和次序相同。這個接收函數有時被稱作receiverslot(注意:接收函數可以與信號數據成員同屬一個類)。接收函數不能有返回值(可以是void)。它必須繼承自sigslot::has_slots<>

            3、  通過呼叫信號數據成員的connect函數,使信號數據成員與接收函數關聯起來,呼叫時傳遞兩個參數:一個是接收函數所在類的對象指針,另一個是類中的接收函數的地址。

            4、  呼叫方使用信號成員就像是調用它自己的函數一樣,傳遞給與信號成員聲明時一致的參數就可以了。如果調用信號成員成功,則所有與此信號成員關聯的任意類中的接收函數都會被調用。

            我們可以把任意數量的信號成員與一個接收函數關系起來。libjingle有時就是把多個信號成員與一個接收函數關聯起來,達到統一處理消息之目的。相反,一些類對象聲明一個信號對象,是為了從一個“信號點”廣播消息(“信號點”語意上講就是一個信號成員對象,此對象關聯了眾多的接收函數,當此信號成員被調用時,這些接收函數都能接收到消息,即這些接收函數都被調用)。當對象(包括信號成員所在對象和傳遞給connect函數的接收函數所屬類對象)被銷毀時,sigslot庫會小心處理取消關聯和引用關系。

            下面的代碼示范了sigslot庫的使用方法:

             

            // Class that sends the notification.

            class Sender {

            // The signal declaration.

            // The &apos;2&apos; in the name indicates the number of parameters. Parameter //types

            // are declared in the template parameter list.

            sigslot::signal2<string message, std::time_t time> SignalDanger;

            // When anyone calls Panic(), we will send the SignalDanger signal.

            void Panic(){

            SignalDanger("Help!", std::time(0));

            }

            // Listening class. It must inherit sigslot.

            class Receiver : public sigslot::has_slots<>{

            // Receiver registers to get SignalDanger signals.

            // When SignalDanger is sent, it is caught by OnDanger().

            // Second parameter gives address of the listener function class definition.

            // First parameter points to instance of this class to receive notifications.

            Receiver(Sender sender){

            sender->SignalDanger.connect(this, &Receiver.OnDanger);

            }

            // When anyone calls Panic(), Receiver::OnDanger gets the message.

            // Notice that the number and type of parameters match

            // those in Sender::SignalDanger, and that it doesn&apos;t return a value.

            void Receiver::OnDanger(string message, std::time_t time){

            if(message == "Help!")

            {

            // Call the police

            ...

            }

            }

            ...

            }

             

            Sender 類聲明了一個信號數據成員:

            sigslot::signal2<string message, std::time_t time> SignalDanger;

                   語句中的“<string message, std::time_t time>”聲明了可以與此信號成員關聯的接收函數的參數形式,必須是 void functionName( string,std::time_t )形式。

                   Sender類的成員數void Panic()實現中可以看到,使用信號成員的形式就像是在調用一個與信號成員同名的函數SignalDanger("Help!", std::time(0));,參數類型就是聲明信號成員時指定的參數。

             

            Receiver類繼承自sigslot::has_slots<>,它的成員函數就具有了成為“接收函數”的“潛質”。

                   Receiver的構造函數可以看出,當Receiver對象創建時,必須向它指定一個信號類(即聲明了信號成員的類)對象作為構建造函數的參數,當然此信號類必須有Receiver定義的操作用到的信號成員的樣式。

                   一旦Receiver類對象被創建,Sender類中的信號成員就與Receiver類中的OnDanger()函數關聯起來了,只要Sender對象的Panic()被調用,Receiver類對象的OnDanger()就被調用,即接收到來自Sender對象的消息,從而進行處理。

            :

             

            Sender sender;

            Receiver  receiver(sender);

            如果 運行:

            sender.Panic();

            receiver.OnDanger();

            被自動調用,在此函數的內部就可以處理來自sender的消息。

            實現了信號類與接收類之間的松偶合性。

             

            libjingle庫中的一些類,發送信號給接收函數(即listeners 監聽者,可理解為某個類的接收函數),用來傳遞一些重要事件。比如:當你發出或收到一個鏈接嘗試時,Call::SignalSessionState就會發出通知信號。在應用程序中應該有接收函數與這些信號關聯起來,并且做出適當的行為。

             

            按照libjingle中的約定,在聲明信號數據成員時,名字被冠以“Signal”字符,比如:SignalStateChange,SignalSessionState,SignalSessionCreate

            與這些信號關聯的函數名被冠以“On,比如:OnPortDestropyed(),OnOutgoingMessage(),OnSendPacket();

             

            關于 sigslot庫的更多內容,請查看sigslot文檔。

             

            若有錯誤,請您指正,thanks!




            posted on 2013-09-01 16:30 楊粼波 閱讀(445) 評論(0)  編輯 收藏 引用

            国产精品内射久久久久欢欢| 亚洲欧美久久久久9999| 久久亚洲精精品中文字幕| 99国产欧美精品久久久蜜芽| 伊人久久综合热线大杳蕉下载| 国产亚洲精午夜久久久久久| 18禁黄久久久AAA片| 精品久久久久久无码专区不卡| 99久久夜色精品国产网站| 欧美日韩精品久久久免费观看| 久久精品国产亚洲av影院| 色婷婷久久久SWAG精品| 国产精品久久成人影院| 伊人久久综合成人网| 国产精品99久久久久久董美香 | 色婷婷综合久久久中文字幕| 久久99国产精品一区二区| 一级做a爰片久久毛片看看| 久久国产精品99精品国产987| 少妇久久久久久被弄到高潮| 99久久国产综合精品网成人影院 | 国产一久久香蕉国产线看观看| 亚洲国产成人久久综合野外| 久久久久四虎国产精品| 欧美丰满熟妇BBB久久久| 波多野结衣久久一区二区| 狠狠人妻久久久久久综合| 国产精品久久久久9999| 亚洲国产精品无码成人片久久 | 亚洲综合日韩久久成人AV| 亚洲精品国精品久久99热| 久久天天躁狠狠躁夜夜不卡| 国产精品成人无码久久久久久| 狠狠色丁香久久婷婷综| 精品国产乱码久久久久久1区2区| 亚洲精品无码久久久久去q| 国内精品久久久久久久久电影网| 久久免费香蕉视频| 久久久精品久久久久特色影视| 91久久福利国产成人精品| 国产—久久香蕉国产线看观看|