前几天,搬房子时又拿起《重构----改善既有代码的设计》这本书来随便翻来看下,重构Refactoring在开发时,是时常也经常会使用得到。

她确实教我们怎样把写程序写简洁,清楚 好明白,好理解,好维护......

今天为博客写点重构相关。以网友实际的例子,在论坛上看到的:

public void show2(string day)
{
string[] str = new string[] { "09:00", "11:00", "12:00", "13:00", "14:00", "15:00", "16:00" };
for (int i = ; i < str.Length; i++)
{
string sql1 = "select position from cwsz where day='" + day + "' and sjd='" + str[i] + "'";
var dt1 = db.ExecuteQuery(sql1);
if (dt1.Rows.Count > )
{
if (dt1.Rows[]["position"] != null)
{
if (str[i] == "09:00")
{
if (dt1.Rows[]["position"].ToString() == "")
dropnine.SelectedIndex = ;
else if (dt1.Rows[]["position"].ToString() == "")
dropnine.SelectedIndex = ;
else if (dt1.Rows[]["position"].ToString() == "")
dropnine.SelectedIndex = ;
else
dropnine.SelectedIndex = ; }
if (str[i] == "10:00")
{
if (dt1.Rows[]["position"].ToString() == "")
dropten.SelectedIndex = ;
else if (dt1.Rows[]["position"].ToString() == "")
dropten.SelectedIndex = ;
else if (dt1.Rows[]["position"].ToString() == "")
dropten.SelectedIndex = ;
else
dropten.SelectedIndex = ;
}
if (str[i] == "11:00")
{
if (dt1.Rows[]["position"].ToString() == "")
dropele.SelectedIndex = ;
else if (dt1.Rows[]["position"].ToString() == "")
dropele.SelectedIndex = ;
else if (dt1.Rows[]["position"].ToString() == "")
dropele.SelectedIndex = ;
else
dropele.SelectedIndex = ;
}
if (str[i] == "12:00")
{
if (dt1.Rows[]["position"].ToString() == "")
droptw.SelectedIndex = ;
else if (dt1.Rows[]["position"].ToString() == "")
droptw.SelectedIndex = ;
else if (dt1.Rows[]["position"].ToString() == "")
droptw.SelectedIndex = ;
else
droptw.SelectedIndex = ;
}
if (str[i] == "13:00")
{
if (dt1.Rows[]["position"].ToString() == "")
tropthir.SelectedIndex = ;
else if (dt1.Rows[]["position"].ToString() == "")
tropthir.SelectedIndex = ;
else if (dt1.Rows[]["position"].ToString() == "")
tropthir.SelectedIndex = ;
else
tropthir.SelectedIndex = ;
}
if (str[i] == "14:00")
{
if (dt1.Rows[]["position"].ToString() == "")
dropfour.SelectedIndex = ;
else if (dt1.Rows[]["position"].ToString() == "")
dropfour.SelectedIndex = ;
else if (dt1.Rows[]["position"].ToString() == "")
dropfour.SelectedIndex = ;
else
dropfour.SelectedIndex = ;
}
}
}
}
}

刚开始看到这段代码时,一眼看上去就发现用户写得很相同的代码,即是冗余。用了很多if...else...。这些都是在书所提及需要重构的问题点。

分几步来重构,先来解决代码冗余的部分,从if最内层开始,Insus.NET已经把不同的标记出来了,看下图:

把相同的代码写一个方法,以后一旦下拉列表的SelectedIndex的维护,只来这个方法修改即可,不必去每一个if内检查,或是查找替换。

然后我们就可以去修改上抽离的代码,Insus.NET把重构部分comment掉:

现在我们把comment的代码删除,变成下面这个样子,代码简洁多了:

但是上面经首次重构之后,if还是太多,学习过设计模式的话,看到这部分程序,自然想起使用《设计模式--中介(Mediator)模式http://www.cnblogs.com/insus/p/4134383.html 中介者模式来解决。只管传入str[i]值进去即可,用户不必明白它是怎样处理与判断,达到封装效果:

运用设计模式来进行重构:

最后一个private int SetSelectIndex(string position)方法,我们也把它移至中介者类别中去了:
所留给用户看到的代码,即是(删除comment):

以面向对象编程来说,上面高亮两行代码,应该它来自一个对象,不管你的程序是使用存储过程还是写SQL语句,我们尽量不要出现在xxx.aspx.cs代码页中:

这样子,在xxx.aspx.cs代码,就可以改为:

现在我们回过头去看中介者SwitchObject类,它最底的私有方法,其实使用了switch方法,在重构之中,也是一个很坏的使用。其实switch即是替代多个if判断。出现多个if时,我们又可以使用中介者模式来解决。

创建一个中介者类:

再来看看Insus.NET怎样对SwitchObject类修改:

重构到这里,整段程序也改得差不多了,但是在SwitchObject类中,还是有些代码是很不稳定的。有可能常被修改,因此,我们还是把它移走。只留下稳定代码:

移到哪里,Insus.NET想把它移至最原始的位置,在移动之前Select()方法,需要小修改一下,期望传入另外一个参数:

回至xxx.aspx.cs的 public void show2(string day)方法:

重构到这里,你还是看到有一个if判断:

似乎改得有点问题,正确来说,当传入的position为空时,它等于4。而不是获取的selectedIndex不等于4时等于4。

重构完毕,最终源程序可从下面链接下载:
http://download.cnblogs.com/insus//Refactoring/RefactoringAndMediator_pattern.rar

开发(ASP.NET程序)把写代码写至最有面向对象味道的更多相关文章

  1. 前端 javascript 写代码方式

    javascript 和python一样可以用终端写代码 写Js代码: - html文件中编写 - 临时,浏览器的终端 console  

  2. 使用 .NET WinForm 开发所见即所得的 IDE 开发环境,实现不写代码直接生成应用程序

    直接切入正题,这是我09年到11年左右业余时间编写的项目,最初的想法很简单,做一个能拖拖拽拽就直接生成应用程序的工具,不用写代码,把能想到的业务操作全部封装起来,通过配置的方式把这些业务操作组织起来运 ...

  3. 没有什么,开发ASP.NET时随便写写,想到什么写什么

    没有什么,开发ASP.NET时随便写写,想到什么写什么,这次想写点开发过程中,比如在数据库,某一张表中有一个字段,如下: 上面代码示例中高亮字段,数据类型为BIT,它存储的值将为"True& ...

  4. C#写文本日志帮助类(支持多线程)改进版(不适用于ASP.NET程序)

    由于iis的自动回收机制,不适用于ASP.NET程序 代码: using System; using System.Collections.Concurrent; using System.Confi ...

  5. 【腾讯Bugly干货分享】深入理解 ButterKnife,让你的程序学会写代码

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/578753c0c9da73584b025875 0.引子 话说我们做程序员的,都 ...

  6. asp代码写的,微信会员报名转发分享带上下级和邀约人关系并且能微信支付asp编号的

    昨天晚上应一个客户要求写了一套代码,实现的功能是: 在微信公众号上注册会员,获取用户的头像和微信名称,进入会员中心报名,报名成功成功后,他如果转发链接给别人,别人打开后则成为他的下级,上面那个算是一个 ...

  7. MySQL 创始人:写代码比打游戏爽,程序员应多泡开源社区

     王练 发布于2017年09月04日 收藏 43   开源中国全球专享福利,云栖大会购票大返现!>>>   根据StackOverflow的最新调查,MySQL仍然是全世界最流行的数 ...

  8. CS代码代写, 程序代写, java代写, python代写, c/c++代写,csdaixie,daixie,作业代写,代写

    互联网一线工程师程序代写 微信联系 当天完成特色: 互联网一线工程师 24-48小时完成.用心代写/辅导/帮助客户CS作业. 客户反馈与评价 服务质量:保证honor code,代码原创.参考课程sl ...

  9. NX二次开发-NX+VS写代码设断点调试技巧

    在做NX二次开发的时候写完代码,编译可以通过,但是执行的时候却没有反应,或者得到的结果不对,说明肯定有地方传值出错了.我在查找代码错误的时候有几种方法:1.uc1601打印函数输入和输出的值看对不对. ...

随机推荐

  1. oracle中查询某张表都被哪些表参照了

    起因: 系统测试的时候发现如果某条记录已经被引用了,这个时候删除这条记录会引起数据不一致,系统会报错.比如警员信息,在考勤记录表里会引用警员ID,如果考勤记录表中已经存在这个警员ID了,这时从警员表中 ...

  2. [转载] Redis

    转载:http://snowolf.iteye.com/blog/1630697 大约一年多前,公司同事开始使用Redis,不清楚是配置,还是版本的问题,当时的Redis经常在使用一段时间后,连接爆满 ...

  3. 卖萌的极致!脸部捕捉软件FaceRig让你化身萌宠

    FaceRig是一款以摄像头为跟踪设备捕捉用户脸部动作并转化为数据套用在其他动画模型上的一款软件,能够应用于一些日常的视频社交软件或网站,比如视频通话软件Skype和直播网站Twitch.FaceRi ...

  4. iOS-Xcode上传后iTunes Connect构建版本不显示

    在升级到Xcode8版本以后大多数人会碰到这个问题-开开心心开发好一款app以后上传到iTunes后台提交审核,然而iTunes Connect后台活动栏里没有出现我们上传的app,确切的说是显示一会 ...

  5. Android实现自适应正方形GridView(陌陌引导页面效果)

    1.http://blog.chengyunfeng.com/?p=465 2.备注,慢慢研究

  6. 关于Python的web框架

    uliwebhttp://git.oschina.net/limodou/uliweb uliweb 吸取了其他框架的经验,集成了orm.总的来说一般.这个安装后有个exe文件,命令行工具.不绿色.个 ...

  7. Axapta 3 COM Connector

    Axapta 3 COM Connector Copy from blog   Having fun setting up the COM+ connector for Enterprise Port ...

  8. 如何在终端实时展现git分支

    在微博上看到ghosTM55在终端可以实时展现出当前运行的分支,觉得很奇特,于是google了一把.这里面存在两个内容,第一个bash,第二个是git bash基础: 了解到linux的shell存在 ...

  9. vs.php调试php使用外部的apache进行调试

    vs.php中使用外部的apache进行调试 一般phper们都会有自己配置好的开发调试环境,那么如何在vs.php中使用自己已经配置好的apache+php环境调试 php程序呢?如下: (1)从官 ...

  10. HIS系统的处方录入控件

    前文<EFW框架Winform前端开发之强大的自定义控件库>中我们介绍了EFW框架中Winform系统中的自定义控件,本章使用自定义控件中的GridBoxCard控件开发了一个HIS系统的 ...