晚上有个沙雕需求,上游请求传过来一个字段,比如是"1;3;2;4;5;6;9;" 那么我按照顺序执行函数 f1(xx),f3(xx),f2(xx)……f9(xx)
伪代码:
exec_vec = phrase_exec_conf(xxxx); or(int i = 0;i < exec_vec.size();i++) call_func(exec_vec[i]);
我晚上自己写了下,不优雅,很垃圾,请教下各位在 C/C++中有没有优雅点的实现?
![]() | 1 binux 2021-10-09 00:27:34 +08:00 via Android 怎么不优雅了? |
2 csfreshman OP @binux 自我感觉垃圾,一会贴上来你看下,C++写的少一些。 |
![]() | 3 msg7086 2021-10-09 05:54:15 +08:00 写一堆 lambda 扔进数组里然后取下标执行? |
![]() | 4 ysc3839 2021-10-09 06:54:00 +08:00 via Android 请放完整代码,仅凭现在提供的代码没法确定最佳方案。 |
5 T0kvgh 2021-10-09 07:52:55 +08:00 std::map< int, std::function< void() > 之前这样稀奇古怪的用过 |
![]() | 6 muzuiget 2021-10-09 08:32:21 +08:00 1. 粗暴,写很多 if 语句 2. 优雅,定义一套 DSL 3. Lua 帮到你 |
![]() | 7 shawnsh 2021-10-09 09:00:29 +08:00 via Android 函数指针加队列 |
8 2i2Re2PLMaDnghL 2021-10-09 09:40:55 +08:00 格林斯潘第十定律 |
9 csfreshman OP @T0kvgh 这不是稀奇古怪的用法,这很常见吧。 |
10 csfreshman OP @ysc3839 昨天睡着忘了贴了,晚上回去贴下我写的 3 个方式。 |
![]() | 13 c0xt30a 2021-10-10 06:26:38 +08:00 感觉这已经是最干净利落的处理方式了,还是不要想着再加戏了吧 |