java 优化switch_Java中 switch-case 如何优化?

代码样式如下:

switch(code) {

case 1:

//调用方法

method1();

break;

case 2:

//调用方法

method2();

break;

case 3:

//调用方法

method3();

break;

case 4:

//调用方法

method4();

break;

case 5:

//调用方法

method5();

break;

case 6:

//调用方法

method6();

break;

case 7:

//调用方法

method7();

break;

case 8:

//调用方法

method8();

break;

case 9:

//调用方法

method9();

break;

case 10:

//调用方法

method10();

break;

case 11:

//调用方法

method11();

break;

case 12:

//调用方法

method12();

break;

case 13:

//调用方法

method13();

break;

case 14:

//调用方法

method14();

break;

case 15:

//调用方法

method15();

break;

case 16:

//调用方法

method16();

break;

case 17:

//调用方法

method17();

break;

default:

//调用方法

methodDefalut();

break;

}

这段switch代码已经是很整洁了,但由于条件太多,switch语句就变得很长了!而且这样写不符合开闭原则,每增加一个条件,就又要修改这段代码!可读性也会随着长度增长而变差!

所以,我想请教各位大佬,如何写一个优雅的代码来替换上面这段代码?

我有已经想到两种方法:

(1)使用容器,每个方法都换成一个类,但这样的话,就要多加 17个类!(如果能解决类的数量过多问题,就好了)

(2)使用反射,但是反射的速度太慢了,这段代码是放在一个接口里面的,性能太差会影响接口吞吐速率!

我们可以看到上面两种方法都有一些缺点,所以我想请教各位,有没有什么更好的方法?谢谢!

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值