C++用boost.signal實現(xiàn)多播委托
boost.signal提供了一個多播委托機制,通過它可以非常容易的實現(xiàn)觀察者模式:
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連接回調(diào),disonnect去連接回調(diào),()運算符執(zhí)行所有回調(diào)。
連接成員函數(shù)
通過lambda表達式也可以非常容易的實現(xiàn)成員函數(shù)的連接:
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(); }
連接帶返回值的函數(shù)
signal也支持帶返回值的函數(shù),和C#一樣,只返回最后一個函數(shù)的返回值。
boost::signal<int ()> sig; sig.connect([](){ return 1; }); sig.connect([](){ return 2; }); sig.connect([](){ return 3; }); cout << sig() << endl;
異常處理
signal的異常處理機制也和c#一樣:遇到異常后停止執(zhí)行,拋出異常。
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實現(xiàn)多播委托的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
詳解_beginthreadex()創(chuàng)建線程
這篇文章主要介紹了詳解_beginthreadex()創(chuàng)建線程,使用_beginthreadex(),需要的頭文件支持#include <process.h> 下面我們就來看看具體的實現(xiàn)吧2022-01-01UE4 Unlua 調(diào)用異步藍圖節(jié)點AIMoveTo函數(shù)示例詳解
這篇文章主要為大家介紹了UE4 Unlua 調(diào)用AIMoveTo函數(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09Visual Studio Code 從簡介、安裝到配置所需插件詳細介紹
這篇文章給大家介紹到vs與vs code的區(qū)別,并且會詳細介紹vscode的安裝步驟,和我所了解過的插件配置,感興趣的朋友跟隨小編一起看看吧2020-03-03Qt QStandardItemModel用法小結(jié)
QStandardItemModel可用作標準Qt數(shù)據(jù)類型的存儲庫,本文主要介紹了Qt QStandardItemModel用法小結(jié),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-12-12