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

            sigslot簡介

            轉載自:http://www.thecodeway.com/blog/?p=85


                在開發(fā)一個復雜工程的時候,經(jīng)常會遇到這樣一個問題:整個系統(tǒng)被分成數(shù)個模塊,每個模塊提供有限的功能,由上層調用組成整個系統(tǒng),為了保證每個模塊的獨立性,我們經(jīng)常會盡量限制模塊與模塊之間的直接聯(lián)系,比如每個模塊只提供有限的API或者COM接口,而內部實現(xiàn)則完全封閉起來。
                但有的時候會出一些設計要求,必須能夠使模塊之間能夠直接通訊,而這兩個模塊往往處于不同的邏輯層次,之間相差甚遠,如何設計它們之間的調用模式使整個工程維持整潔變得非常困難,比如模塊直接直接包含對方的頭文件會引起編譯變得復雜,提供api或者接口會引起版本危機等問題。
                sigslot的出現(xiàn)為我們提供了一種解決問題的思想,它用“信號”的概念實現(xiàn)不同模塊之間的傳輸問題,sigslot本身類似于一條通訊電纜,兩端提供發(fā)送器和接收器,只要把兩個模塊用這條電纜連接起來就可以實現(xiàn)接口調用,而sigslot本身只是一個輕量級的作品,整個庫只有一個.h文件,所以無論處于何種層次的庫,都可以非常方便的包含它。

                舉個例子,我們設計一個發(fā)送消息的類,這個類負責在某種時刻向外界發(fā)出求救信號

            // Class that sends the notification.
            class Sender  
            {
            public:
                
            // The signal declaration. 
                
            // The ‘2′ in the name indicates the number of parameters. Parameter types 
                
            // are declared in the template parameter list.
                sigslot::signal2< std::string , int > SignalDanger;
                
                
            // When anyone calls Panic(), we will send the SignalDanger signal.
                void Panic()
                
            {
                    SignalDanger(
            "Help!"0); 
                }

            }
            ;

            另外一個類則負責接收求助信號
             
            // Listening class. It must inherit sigslot.
            class Receiver : public sigslot::has_slots<>
            {
            public:
                
            // 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’t return a value.
                void OnDanger(std::string message, int time)
                
            {
                    printf(
            "I heard something like \"%s\" at %d!\n", message.c_str(), time);
                }

            }
            ;

            現(xiàn)在讓我們在主邏輯中把這兩個類連接起來

            Sender sender;
            Receiver receiver;
             
            // 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.
            sender.SignalDanger.connect(&receiver, Receiver::OnDanger);

            只要在任何時候調用 sender.Panic()函數(shù),就會把求救信號發(fā)送給接收者,而且這兩個發(fā)送和接收端的模塊都可以獨立編譯,不會出現(xiàn)版本問題。

            posted on 2010-02-24 20:21 楊粼波 閱讀(1219) 評論(1)  編輯 收藏 引用

            評論

            # re: sigslot簡介 2010-02-25 17:24 ccsdu2009

            呵呵 你也關注過這個庫啊
            其實不考慮線程安全的話
            gui庫glooey總改造了的sigslot是很簡單的  回復  更多評論   

            精品久久久久久国产三级| 武侠古典久久婷婷狼人伊人| 久久精品国产亚洲av麻豆蜜芽| 国产亚洲成人久久| 久久久久久久久久久精品尤物| 国产精品禁18久久久夂久 | 久久精品无码一区二区三区免费| 久久一区二区三区免费| 国产精品久久久久久久久久影院| 7777久久亚洲中文字幕| 伊人久久大香线蕉综合网站| 久久九九亚洲精品| 亚洲国产精品无码成人片久久 | 国产福利电影一区二区三区,免费久久久久久久精 | 蜜臀久久99精品久久久久久小说| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久996热精品xxxx| 国内精品久久久久久99蜜桃| 久久人人爽人人精品视频| 精品熟女少妇av免费久久| 欧美久久久久久精选9999| 精品午夜久久福利大片| 人妻无码久久一区二区三区免费| 欧美一级久久久久久久大片| 国产高清美女一级a毛片久久w| 无码人妻精品一区二区三区久久| 亚州日韩精品专区久久久| 久久免费观看视频| 久久亚洲2019中文字幕| 国产激情久久久久影院老熟女 | 精品欧美一区二区三区久久久| 国产成人综合久久综合| 浪潮AV色综合久久天堂| 久久久女人与动物群交毛片| 久久SE精品一区二区| 中文字幕久久波多野结衣av| 精品久久久中文字幕人妻| 久久精品国产亚洲αv忘忧草| 久久久久久久精品妇女99| 无码国产69精品久久久久网站| 少妇内射兰兰久久|