swich....case 条件分支多了之后,会严重的破坏程序的美观性。
比如这个

上述代码是用于两个进程之间通信的代码,由于通信的枚举特别的多,所以case的分支特别的多。导致了代码的可读性,可维护性严重下降。经过查找资料和重构,想到了一种可行的在这种情况替代switch...case的方案——————利用键值对。

声明键值对对象

针对进程通信的代码逻辑,构建了如下的键值对。

Dictionary<EnumMsg, Action<Message>> mMessageReceiver = new Dictionary<EnumMsg, Action<Message>>();

这个键值对的键是自定义的消息枚举,值是Action<Message>的委托。这样消息枚举和消息枚举对应的处理函数就一一对应了。

初始化时注册消息

在初始化时,将枚举与相应的Action进行装载。

private void SubscribeMessageReceiver(){    mMessageReceiver.Add(EnumMsg.SEND_PANO_PARAM, UpdatePano);    mMessageReceiver.Add(EnumMsg.CMD_PANO_VIEW, ExecutePanoViewCommand);    mMessageReceiver.Add(EnumMsg.CMD_PANO_LENGTH_MEASURE, ExecuteLengthMeasure);    mMessageReceiver.Add(EnumMsg.CMD_PANO_AREA_MEASURE, ExecuteAreaMeasure);    mMessageReceiver.Add(EnumMsg.CMD_PANO_QUICK_PICK, ExecuteQickPickCommand);}

这样就把键值对对象构建完成。那么就可以将重构swith...case代码段了。

修改switch...case代码段

重构前的switch....case代码

  protected override void DefWndProc(ref Message m)        {            switch (m.Msg)            {                case ((int)API.WM_COPYDATA):                    {                        switch ((int)m.WParam)                        {                            case ((int)Procedure.OpenSkyline):                                   m = OpenSkylineView(m);                                break;                            case ((int)Procedure.Measureare):                                 m = Measure(m);                                break;                            case ((int)Procedure.Measurelength):                                 m = Measure(m);                                break;                        }                    }                    break;                default:                    break;            }            base.DefWndProc(ref m);        }

基于键值对来查找对应的处理方法的代码

        protected override void DefWndProc(ref Message m)        {            base.DefWndProc(ref m);            if (m.Msg == (int)API.WM_COPYDATA)            {                EnumPanoMsg pEnumPanoMsg = (EnumPanoMsg)m.WParam;                if (mMessageReceiver.Keys.Contains(pEnumPanoMsg))                {                    mMessageReceiver[pEnumPanoMsg](m);                }            }        }

根据键值对的键来进行查找,当需要增加新的case分支的时候,原本的方法需要更改switch....case分支,但是利用键值对的方法,只需要编写新的处理方法,并且在键值对中增加新的一对键值就可以了。代码简洁美观,没有一长串令人厌烦的case了。

更多相关文章

  1. .Net实现微信JS-SDK分享功能代码展示
  2. C#中关于程序功能实现以及对代码选择的思考
  3. .net中关于异步性能测试的示例代码
  4. ASP.NET Core中用户登录验证实现最低配置的示例代码
  5. 代码详解AVL树的插入
  6. 厌倦写代码的人是如何做软件开发的
  7. 一招搞定C++调用Lua代码配置文件函数(附代码)
  8. C#/基于Unity 行为树的实现步骤【纯代码】
  9. 简要分析Unity计时器脚本Timer的用法(附代码)

随机推荐

  1. Android(安卓)View总结
  2. 升级博客网站遇到的坑
  3. bootstrap高亮显示代码,且横向滚动
  4. 对Java之父的感谢多于敬仰
  5. Android(安卓)App Widget中如何调用Remot
  6. 啃一啃 Spring 的官方文档
  7. Java中的读写锁ReadWriteLock
  8. Collection总览
  9. Java 自动提交 git
  10. java后端面试高薪必备知识点-WeakHashMap