您好,登錄后才能下訂單哦!
本篇內容主要講解“C++怎么用boost.signal實現多播委托”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“C++怎么用boost.signal實現多播委托”吧!
boost.signal提供了一個多播委托機制,通過它可以非常容易的實現觀察者模式:
void print_sum(float x, float y) { std::cout << "The sum is " << x+y << std::endl; } void print_product(float x, float y) { std::cout << "The product is " << x*y << std::endl; } void print_difference(float x, float y) { std::cout << "The difference is " << x-y << std::endl; } int main() { boost::signal<void (float, float)> sig; sig.connect(print_sum); sig.connect(print_product); sig.connect(print_difference); sig(5, 3); }
signal對象的使用方式非常簡單,connect連接回調,disonnect去連接回調,()運算符執行所有回調。
通過lambda表達式也可以非常容易的實現成員函數的連接:
struct A { int value; A(int value) : value(value) {} void Foo() { cout << "a has value of " << value << endl; } }; int main() { A a(123); boost::signal<void ()> sig; sig.connect([&]() {a.Foo();}); sig(); }
signal也支持帶返回值的函數,和C#一樣,只返回最后一個函數的返回值。
boost::signal<int ()> sig; sig.connect([](){ return 1; }); sig.connect([](){ return 2; }); sig.connect([](){ return 3; }); cout << sig() << endl;
signal的異常處理機制也和c#一樣:遇到異常后停止執行,拋出異常。
sig.connect([](){ cout << "foo 1" << endl; }); sig.connect([](){ throw std::exception("foo 2 fail"); }); sig.connect([](){ cout << "foo 3" << endl; }); try { sig(); } catch (std::exception& error) { cout << error.what() << endl; }
到此,相信大家對“C++怎么用boost.signal實現多播委托”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。