免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3109 | 回复: 8
打印 上一主题 下一主题

[算法] 有没有轻量级的信号槽实现 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-11-04 14:54 |只看该作者 |倒序浏览
QT的信号槽机制挺好用,但是需要moc,想知道有没有轻量级的实现?

在sourceforge看到一个YSIGNAL,但是它自己的例子都编译不过  ……

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
2 [报告]
发表于 2015-11-04 17:37 |只看该作者
boost.signal2

论坛徽章:
14
水瓶座
日期:2014-06-10 09:51:0215-16赛季CBA联赛之江苏
日期:2017-11-27 11:42:3515-16赛季CBA联赛之八一
日期:2017-04-12 14:26:2815-16赛季CBA联赛之吉林
日期:2016-08-20 10:43:1215-16赛季CBA联赛之广夏
日期:2016-06-23 09:53:58程序设计版块每日发帖之星
日期:2016-02-11 06:20:00程序设计版块每日发帖之星
日期:2016-02-09 06:20:0015-16赛季CBA联赛之上海
日期:2015-12-25 16:40:3515-16赛季CBA联赛之广夏
日期:2015-12-22 09:39:36程序设计版块每日发帖之星
日期:2015-08-24 06:20:002015亚冠之德黑兰石油
日期:2015-08-07 09:57:302015年辞旧岁徽章
日期:2015-03-03 16:54:15
3 [报告]
发表于 2015-11-04 18:12 |只看该作者
猫哥,还有什么你不会的吗?

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
4 [报告]
发表于 2015-11-04 19:31 |只看该作者
猫哥,还有什么你不会的吗?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
5 [报告]
发表于 2015-11-04 21:04 |只看该作者
N 年前,还是 c++0x 时代码过一个 百多行的

https://github.com/fengwang/signal0x

一个 singleton 加一个 function container 再加一个 signal

现在让我重写,  singleton 不会变,function container (chain_function) 会用  c++14 重写,signal 也不用变;
有兴趣去看看好了

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
6 [报告]
发表于 2015-11-04 21:42 |只看该作者
回复 5# lost_templar

signal/slot有一个讨厌的地方,那就是signal的owner如果被干掉了怎么办。
假如说你用一个member function当signal,连接到一个slot上,你必须确保这个member function所引用的对象的生存期超出slot owner的生存期,否则当slot触发signal的时候程序就挂了,要不然你就要确保当这个对象被干掉时自动解除signal和slot的连接,如果你用shared_ptr/weak_ptr来实现就必须要求这个对象本身的生存期一定要由shared_ptr来管理,可问题是C++没法提供这种保障。
其余的语法之类的问题其实都是小问题。

没太仔细研究过QT里面的signal/slot是怎么实现的,但我觉着想要实现这种东西有GC肯定会方便不少。

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
7 [报告]
发表于 2015-11-04 22:50 |只看该作者
windoze 发表于 2015-11-04 21:42
回复 5# lost_templar

signal/slot有一个讨厌的地方,那就是signal的owner如果被干掉了怎么办。


这是最困难的地方,我直接用 std::function 了,没有考虑对象生命周期。
翻了下 libc++2,没有看明白它是怎么做的。
有时间看看 boost::signal,估计它的代码更好读一点

论坛徽章:
154
2022北京冬奥会纪念版徽章
日期:2015-08-07 17:10:5720周年集字徽章-年
日期:2022-10-26 16:44:2015-16赛季CBA联赛之深圳
日期:2022-11-02 14:02:4515-16赛季CBA联赛之八一
日期:2022-11-28 12:07:4820周年集字徽章-20	
日期:2023-07-19 08:49:4515-16赛季CBA联赛之八一
日期:2023-11-04 19:23:5115-16赛季CBA联赛之广夏
日期:2023-12-13 18:09:34
8 [报告]
发表于 2015-11-07 13:02 |只看该作者
尽量保证自己的业务代码清爽简洁,少在这些问题上专研吧,没有太大现金价值和时间价值

论坛徽章:
9
程序设计版块每日发帖之星
日期:2015-10-18 06:20:00程序设计版块每日发帖之星
日期:2015-11-01 06:20:00程序设计版块每日发帖之星
日期:2015-11-02 06:20:00每日论坛发贴之星
日期:2015-11-02 06:20:00程序设计版块每日发帖之星
日期:2015-11-03 06:20:00程序设计版块每日发帖之星
日期:2015-11-04 06:20:00程序设计版块每日发帖之星
日期:2015-11-06 06:20:00数据库技术版块每周发帖之星
日期:2015-12-02 15:02:47数据库技术版块每日发帖之星
日期:2015-12-08 06:20:00
9 [报告]
发表于 2015-11-07 13:08 |只看该作者
本帖最后由 wlmqgzm 于 2015-11-07 13:35 编辑

boost signal2 还是比较简单的实现方法, 做代码比较容易, 学习难度也不高, 有标准范例可学,   
最简单的就是 函数对象, 就是相当于1:1的signal2
还有干脆就是自己结合map做一个类似signal2的东西, 下面有范例代码:

总之, 学会boost, 各类工具就都比较齐全了, 开工更容易,代码错误更少,
缺点就是: 代码的总行数比较少, 工作业绩考核吃亏.
  1. #include <iostream>
  2. #include <map>
  3. #include <functional>
  4. using namespace std;

  5. // 普通函数
  6. int add(int i, int j) { return i + j; }
  7. // lambda表达式
  8. auto mod = [](int i, int j){return i % j; };
  9. // 函数对象类
  10. struct divide
  11. {
  12.         int operator() (int denominator, int divisor)
  13.         {
  14.                 return denominator / divisor;
  15.         }
  16. };

  17. int main(int argc, char *argv[])
  18. {
  19.         map<char, function<int(int, int)>> binops =
  20.         {
  21.                 { '+', add },
  22.                 { '-', minus<int>() },
  23.                 { '*', [](int i, int j){return i - j; } },
  24.                 { '/', divide() },
  25.                 { '%', mod },
  26.         };
  27.         cout << binops['+'](10, 5) << endl;
  28.         cout << binops['-'](10, 5) << endl;
  29.         cout << binops['*'](10, 5) << endl;
  30.         cout << binops['/'](10, 5) << endl;
  31.         cout << binops['%'](10, 5) << endl;
  32.         system("pause");
  33.         return 0;
  34. }
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP