面对很多是switch case 语句如何优化

psl1203 2011-12-21 09:03:45
switch(b)
{
case 1:
语句.....
break;

case 3:
语句.....
break;


case 5:
语句.....
break;


case 7:
语句.....
break;


case 8:
语句.....
break;


case 10:
语句.....
break;


case 12:
语句.....
break;


case 13:
语句.....
break;

case 14:
语句.....
break;


case 16:
语句.....
break;


case 19:
语句.....
break;


case 20:
语句.....
break;


default:
}
system("pause");
return 0;
}

类似这样的.其实还有嵌套witch 有什么好方法优化去掉witch语句.每个case处理不一样的事情.表驱动法好象可以.还有什么更好的方法不?
...全文
2298 16 打赏 收藏 转发到动态 举报
写回复
用AI写文章
16 条回复
切换为时间正序
请发表友善的回复…
发表回复
Binzo 2011-12-29
  • 打赏
  • 举报
回复
case 0:
case 1:
case 2:
//do something
break;
//适用于做相同处理的情况。
onlycs 2011-12-24
  • 打赏
  • 举报
回复
嗯,map不错,效率比if..else;switch..case高
lgstudyvc 2011-12-24
  • 打赏
  • 举报
回复
[Quote=引用 11 楼 psl1203 的回复:]
谢谢 各位 目前采用map
[/Quote]
map不错 可以一对一的,偶也用
psl1203 2011-12-24
  • 打赏
  • 举报
回复
谢谢 各位 目前采用map
baby393 2011-12-24
  • 打赏
  • 举报
回复
论速度switch已经是最快的了,建议switch语句里面default放在开头,这样编译器更容易优化
switch (..)
{
default:
break;
case 1:
break;
...
  • 打赏
  • 举报
回复
函数指针+map
dfasri 2011-12-23
  • 打赏
  • 举报
回复
你可以采用:

switch
case 1, 2, 3, 4, 5, 6, 7, 8, 9, 10.....
return value;
case 100, 1012, XXX, NNN.....
call MapFunc();

这样应该会好看点, 即实现简单返回, 也实现用MAP控制函数.
盛夏 2011-12-22
  • 打赏
  • 举报
回复
同求lz的问题!优化程序!
ysjyniiq 2011-12-22
  • 打赏
  • 举报
回复
没看清楚表驱动法,我的可以是表驱动法了,呵呵~。
其实case太多,大部分是设计问题。如果确实需要,而且还是离散了,就像楼上说过那样,采用哈希,用STL的map或者hash map,做映射。
ysjyniiq 2011-12-22
  • 打赏
  • 举报
回复

//使用函数指针数组
typedef void * (*caseFnType)(void * p1, void * p2);//参数跟返回值,根据实际情况定

void fnCase1(void * p1, void * p2){....}
void fnCase2(void * p1, void * p2){....}
void fnCase3(void * p1, void * p2){....}
void fnCaseN(void * p1, void * p2){....}

caseFnType fn[]=
{
fnCase1,
fnCase2,
fnCase3,
....
fnCaseN
};


//===================
//原来函数是
void Test(int b)
{
....
switch(b)
{

ase 1:
语句.....
return......;


case 2:
return......;
}
}

//现在函数是
void Test(int b)
{
...
if (b< _countof(fn)) //防止越界
{
fn[b](xxx,xxx,xxx);
}
}

hunter0395 2011-12-22
  • 打赏
  • 举报
回复
如果case很多并且数值比较稠密的话,用函数指针数组是一个比较好的选择。定义好枚举类型,可读性也不错。
psl1203 2011-12-22
  • 打赏
  • 举报
回复
逻辑分支太多影响效率啊.实际上是有几十个case. 这个目前可以通过表驱动法做.

还有一函数 switch 也有几十个.形如下面的
case 1:
语句.....
return......;


case 2:
return......;


case 3:
switch
case 1:
.
.
return...;

有些情况需要处理 有些情况不需要处理.也有多达几十个. 将每个case写成函数后用指针函数也不好写.因为有些情况直接返回结果就可以.有些还有嵌套witch ... 谁有比较好方法指教指教

战在春秋 2011-12-22
  • 打赏
  • 举报
回复
也可以使用stl map机制。
dfasri 2011-12-22
  • 打赏
  • 举报
回复
switch 语句有什么不好的...?嫌效率低? 还是嫌它不好看?
wwzzz 2011-12-22
  • 打赏
  • 举报
回复
其实只要代码易读就好。弄太复杂的可能会带来很多问题。
用户 昵称 2011-12-21
  • 打赏
  • 举报
回复
很不错的,总比写if else还强一点点吧。

另外可以考虑函数指针数组。

switch case,最后的汇编语句也会变成cmp 与 jmp,也就是仍然是if else if这种形式,所以只要代码看起来舒服,读起来易懂就行了。

16,473

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧