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