本篇內容主要講解“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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。