免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: image_s
打印 上一主题 下一主题

[C] 如何实现linux c下的观察者模式,有推荐的基础库没 [复制链接]

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
11 [报告]
发表于 2016-01-25 14:14 |只看该作者
queue+mutex+cond,这不是基础开发知识吗。

论坛徽章:
0
12 [报告]
发表于 2016-01-25 22:58 |只看该作者
本帖最后由 image_s 于 2016-01-25 23:11 编辑

回复 10# hanxin83


   “ C/C++的人爱直接开个TCP端口, 谁订阅, 谁连接上来, 我有事抄送你一份.....”

这种方法是可以解决我提到的问题,但是会稍显麻烦,比如有五个线程,1,2,3,4,5,6

1产生a事件
2产生b事件
3.....c事件

2,4,5,6都关心a事件,那就都要和1建立连接,

1,3,5,6都关心b事件,也要分别于2建立连接,

这样每个线程要想获取关心的事件都要了解是哪个线程产生,在哪个端口,地址。

而java或android中,我只需要订阅下我关心的事件,注册回调就好了,完全不关心事件的产生者,并且如果事件的产生有两个以上的话,上面的连接数量就要翻n倍。



另外我是一直做c/c++的,只是了解过android的,发现有些架构的东西确实是有它的好处的。

论坛徽章:
0
13 [报告]
发表于 2016-01-25 22:58 |只看该作者
回复 11# linux_c_py_php


    这个的确是基础,只是开发起来太麻烦,复杂度很高!

论坛徽章:
0
14 [报告]
发表于 2016-01-25 23:10 |只看该作者
回复 7# zhanglin496



谢谢你的回复,我看了下ubus貌似是我需要的东西,不过还没时间仔细看,明天研究下,netlink应该不需要,不涉及内核,unix socket应该可以搞定了。
另外我昨天基于unix socket做了个模型,原理应该差不多,就是做一个server管理接受订阅,分发事件,做个转发,这样目的只是想让订阅方,不关心事件发起方的细节,来解耦。
之所以开这个贴就是感觉应该有一些解决这个需求的库(这个需求感觉应该还蛮普遍的),不想自己造轮子,不过找了一圈没看到,就先自己写个,自己用用了。




论坛徽章:
1
程序设计版块每日发帖之星
日期:2015-10-21 06:20:00
15 [报告]
发表于 2016-02-23 14:22 |只看该作者
redis咋实现的啊?

论坛徽章:
0
16 [报告]
发表于 2016-02-23 20:49 |只看该作者
对的,redis就行了。

其实楼主没说清楚,你的程序是单进程还是多进程?多进程的话开个redis,甚至各种MQ服务都可以,基本上主流的MQ服务都有C客户端SDK的。

论坛徽章:
0
17 [报告]
发表于 2016-02-23 20:50 |只看该作者
另外,zookeeper也不错。

论坛徽章:
0
18 [报告]
发表于 2016-02-24 22:49 |只看该作者
回复 16# xphh2008


    redis对于我的需求太重型了,嵌入式设备上跑的。不过打算看下redis怎么实现的,看能不能把MQ部分剥离出来。谢谢!

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP