OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 6082|回复: 7

C语言怎么处理大量选择的情况?

[复制链接]

20

主题

81

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1180
金钱
1180
注册时间
2018-9-11
在线时间
132 小时
发表于 2018-11-22 17:03:11 | 显示全部楼层 |阅读模式
10金钱
我最近在编程的时候遇到了一个情况,需要处理大量的选项,
例如
if(i==1){}
if(i==2){}
if(i==3){}
if(i==4){}
。。。。。

个人觉得如果if的情况太多是不是会影响效率。。。
请问C语言或C++有没有什么办法处理这种需要大量选择情况?
switch和if比效率如何?

有没有大神来分享一下经验!!

最佳答案

查看完整内容[请看2#楼]

使用函数指针数组。 typedef int (*pFunc)(int) pFunc apFunc[ 64 ] = //假设你有64个分支 { Func00, Func01, Func02, .... }; 函数如下: int Func01 (int i) { // 这里放的是 if ( 1 == i ) { 花括弧里的代码 } } 最后,以i为下标,访问这个数组 apFunc[ i ] ( 参数 )完成功能调用。 apFunc[ i ] ( m ); //这个调用代替对i 从0 到 63 的if或 ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
14
金钱
14
注册时间
2019-9-16
在线时间
0 小时
发表于 2018-11-22 17:03:12 | 显示全部楼层
使用函数指针数组。

typedef    int    (*pFunc)(int)

pFunc     apFunc[ 64 ]  =   //假设你有64个分支
{
     Func00,
      Func01,
     Func02,
     ....
};

函数如下:
int Func01 (int i)
{
     // 这里放的是 if (  1 == i ) {  花括弧里的代码 }
}

最后,以i为下标,访问这个数组  apFunc[ i ] ( 参数 )完成功能调用。

apFunc[ i ] ( m );   //这个调用代替对i 从0 到 63 的if或swich。


如果你的数量级继续加大,可用分段法,分别建数组。
加入以64为一组,再分64组,可以解决 64*64 = 4K个分支
用  i/64  选组(求效率可以右移5位),用 i%64 选组内偏移(求效率可以与0x1F)。

apFunc[ i/64 ] [ i%64  ]( m );

64,只是个例子,你可以选择其他值。但最好是2的幂的整数倍
回复

使用道具 举报

33

主题

982

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
7862
金钱
7862
注册时间
2014-8-13
在线时间
1584 小时
发表于 2018-11-22 17:15:31 | 显示全部楼层
本帖最后由 mack13013 于 2018-11-22 17:18 编辑

常规就是数组,stl容器之类,再复杂就要上索引,数据库,更复杂就分布式。分布式没搞过。其他的,都要看成本的,比如几万个数据的话,随便数组链表或者stl容器就够了,但是几十TB数据的查询,基本上无论那种方法,开销都会很高了,但是使用数据库或者是分布式至少能有个解决方案,使用数组什么的可能是做不出来的

至于if和switch的话,要看优化等级,有些优化会把switch搞成类似数组之列的地址映射,不优化的话,switch和if...else if应该差不多的
回复

使用道具 举报

0

主题

113

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3317
金钱
3317
注册时间
2017-12-14
在线时间
405 小时
发表于 2018-11-22 17:18:23 | 显示全部楼层
如果你每样选择的处理内容都不一样,那在前面加if又有多大的影响呢?如果让你来创造这个C语言,你会用什么方式来表达呢?如果根本就不可能有多简便的方法,那还需要别人给你答案不?
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165353
金钱
165353
注册时间
2010-12-1
在线时间
2108 小时
发表于 2018-11-23 02:05:08 | 显示全部楼层
用switch 好点
回复

使用道具 举报

26

主题

1538

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
6379
金钱
6379
注册时间
2015-8-25
在线时间
1004 小时
发表于 2019-11-29 09:20:28 | 显示全部楼层
刘福财 发表于 2018-11-22 17:03
使用函数指针数组。

typedef    int    (*pFunc)(int)

感谢分享
He who fights with monsters should look to it that he himself does not become a monster, when you gaze long into the abyss, the abyss also gazes into you.
过于执着就会陷入其中,迷失自己,困住自己。
回复

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
7
金钱
7
注册时间
2019-12-1
在线时间
1 小时
发表于 2019-12-1 12:06:03 | 显示全部楼层
刘福财 发表于 2018-11-22 17:03
使用函数指针数组。

typedef    int    (*pFunc)(int)

这个方法厉害了,收藏一份,谢谢!
回复

使用道具 举报

0

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
54
金钱
54
注册时间
2016-3-3
在线时间
9 小时
发表于 2020-2-12 14:41:00 | 显示全部楼层
这个学习了
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-25 11:30

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表