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


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

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

            // 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);
                }

            }
            ;

            現在讓我們在主邏輯中把這兩個類連接起來

            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()函數,就會把求救信號發送給接收者,而且這兩個發送和接收端的模塊都可以獨立編譯,不會出現版本問題。

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

            評論

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

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

            狠狠色丁香婷婷综合久久来来去 | 精品无码久久久久久午夜| 久久天天婷婷五月俺也去| 中文字幕乱码人妻无码久久| 丰满少妇高潮惨叫久久久| 久久综合狠狠综合久久97色| 精品一二三区久久aaa片| 久久亚洲国产午夜精品理论片| 亚洲欧美成人久久综合中文网 | 久久ww精品w免费人成| 久久996热精品xxxx| 久久婷婷五月综合97色| 日日狠狠久久偷偷色综合免费| 国产精品美女久久久m| 久久无码高潮喷水| 色综合久久久久| 99久久婷婷国产综合亚洲| 日本精品一区二区久久久| 91久久精品无码一区二区毛片| 久久伊人五月丁香狠狠色| 亚洲国产成人久久综合野外| 国产精品青草久久久久福利99| 97久久精品午夜一区二区| 中文精品久久久久人妻不卡| 一本色道久久综合狠狠躁篇 | 无码精品久久久天天影视| 欧美一级久久久久久久大片| 国产综合成人久久大片91| 久久久久久亚洲Av无码精品专口| 性欧美大战久久久久久久| 国产精品成人99久久久久| 久久91亚洲人成电影网站| 久久国产精品77777| 久久大香香蕉国产| 久久久久久国产精品无码下载| 国产精品一区二区久久精品涩爱 | 久久久噜噜噜久久熟女AA片| 亚洲午夜久久久久久久久久| 亚洲中文字幕无码久久2020| 99精品国产99久久久久久97| 亚洲国产另类久久久精品小说|