免费注册 查看新帖 |

Chinaunix

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

[C] 有状态算法怎么写比较好 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-06-21 22:47 |只看该作者 |倒序浏览
同一个算法有N种实现,每个实现都有些字段是独有的,保存状态用的那个结构体改来改去,每实现一种实现就要加几个字段。同一个处理函数,在不同的实现下细节还不一样

怎么处理比较好呢?大家有什么经验

论坛徽章:
0
2 [报告]
发表于 2009-06-21 22:54 |只看该作者
这不是典型的switch case然后选择处理函数的情形吗?

当然,如果用C++还可以使用设计模式.

论坛徽章:
0
3 [报告]
发表于 2009-06-21 23:08 |只看该作者
原帖由 converse 于 2009-6-21 22:54 发表
这不是典型的switch case然后选择处理函数的情形吗?

当然,如果用C++还可以使用设计模式.


switch当然可以,只是想看看大家有啥更好的办法没有。
见过一种设计是使用ascii码微语言,用一个字母表示一个处理,然后一个字符串就表示一个处理流程,处理时就逐字节遍历,字符串遍历完,数据也处理完
还有用mask标记的,
还有用OO方法实现的
还有用正则时,那种先compile再处理的

想多了解点

论坛徽章:
1
寅虎
日期:2014-11-30 21:25:54
4 [报告]
发表于 2009-06-22 01:21 |只看该作者
想像一个二维数组 int (*f[max_state][max_event])() 当一个事件e发生在s状态 就可以用f[e]()来处理了 这是我对有状态的事件触发机制的理解 没实践过

论坛徽章:
0
5 [报告]
发表于 2009-06-22 05:41 |只看该作者
跳转表?
要不?else if?

论坛徽章:
0
6 [报告]
发表于 2009-06-22 07:39 |只看该作者
搞那么复杂干啥?状态机就是读取状态表再action,状态表就是函数指针表,函数指针就是用来jump的。还要猥琐的方法么?

论坛徽章:
224
2022北京冬奥会纪念版徽章
日期:2015-08-10 16:30:32操作系统版块每日发帖之星
日期:2016-02-18 06:20:00操作系统版块每日发帖之星
日期:2016-03-01 06:20:00操作系统版块每日发帖之星
日期:2016-03-02 06:20:0015-16赛季CBA联赛之上海
日期:2019-09-20 12:29:3219周年集字徽章-周
日期:2019-10-01 20:47:4815-16赛季CBA联赛之八一
日期:2020-10-23 18:30:5320周年集字徽章-20	
日期:2020-10-28 14:14:2615-16赛季CBA联赛之广夏
日期:2023-02-25 16:26:26CU十四周年纪念徽章
日期:2023-04-13 12:23:1015-16赛季CBA联赛之四川
日期:2023-07-25 16:53:45操作系统版块每日发帖之星
日期:2016-05-10 19:22:58
7 [报告]
发表于 2009-06-22 11:42 |只看该作者

论坛徽章:
0
8 [报告]
发表于 2009-06-22 12:14 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
9 [报告]
发表于 2009-06-22 12:55 |只看该作者
指针啊,回调啊之类的,C++的虚函数也行

论坛徽章:
0
10 [报告]
发表于 2009-06-22 13:03 |只看该作者
也不是自动机,处理视频的算法大概就

typedef struct XX* XXXX

int XXXX_Alloc(...);
int XXXX_Free(...);

int XXXX_LoadFrame(....);
int XXXX_YYYY(...);
的样子

让俺郁闷的地方是一个算法有N种实现,每个实现处理起来细节不同,要分开处理,但更郁闷的是虽然不同,但大体上还是差不多,俺不想把一个函数拷贝一份,然后改个名再改两行
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP