闲谈高效率编程(一)——代码重构.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
闲谈高效率编程(一)——代码重构

 HYPERLINK /walkingp/archive/2009/10/14/1583188.html 闲谈高效率编程(一)——代码重构 之前在一个博客里看到高手与菜鸟的区别无非有三点:1、清晰规范的文档及注释 2、更少的代码 3、模块内高内聚,模块间低耦合;当然从实际项目编码方面讲这三点基本概括了代码质量的含义,软件=程序+文档,谁也无法否认。 读过冗长缺乏注释的代码吧?那你肯定体会到文档及注释的重要性了,我们团队里一个成员习惯代码从不注释,我讲到代码规范时他总是说自己的代码自己记 得,后来他离职了,留下的代码被团队称为“天书”,——混乱的变量命名、团队成员戏言“花一个月读懂代码,花两个月修改代码”,而实际上整个项目的周期不 过几个月,接手该人的代码的那位于是出现想删不舍不得删(毕竟上万行!),想改又改不了的窘境。 程序员要劳记三种变量命名方式:Camel命名、Pasaca命名和匈牙利命名,javascript方法普遍采用Camel命名,而C#中普遍采 用Camel(普通变量)加Pasaca(方法)命名。当然我本人还有一份命名方法(应该不是原创),就是对文件及QueryString字符串使用小写 英语单词缩写及加下划线,如manage_news_list.aspx?news_class_id=1。 个人认为菜鸟容易出现的变量名就是”懒惰“的变量名,比如GridView1、Form1、LinkButton1……,想象一下一个页面有上百个 TextBox,到最后TextBox100的时候你应该不会很好过吧。类似的有文件名Default1.aspx,..Default6.aspx,控 件名、方法名、变量名,最bt的是有些人发过来代码让我改,解压出来是这个样子 哪让程序都是外国人开发的呢?:( 同样的功能,高手的代码往往短小精悍,令人击节叹赏。 差的程序往往“千姿百态” 过多循环嵌套 无注释(上百个字段哦) 还有就是“代码行数”的问题,以下代码 ? ?1int?count?=?0; ?2if?(ViewState[reply]?!=?null) ?3{ ?4????string?name?=?txtKey.Text.Trim().ToString(); ?5????GridDocReply.DataSource?=?bllDocReply.GetModelList(Reply_Title?like?‘%?+?name?+?%’?+?or?Reply_PostAuthor?like?‘%?+?name?+?%’); ?6????GridDocReply.DataBind(); ?7????count?=?bllDocReply.GetModelList(Reply_Title?like?‘%?+?name?+?%’?+?or?Reply_PostAuthor?like?‘%?+?name?+?%’).Count; ?8} ?9else 10{ 11????GridDocReply.DataSource?=?bllDocReply.GetAllList(); 12????GridDocReply.DataBind(); 13????count?=?bllDocReply.GetAllList().Tables[0].Rows.Count; 14} 改进后 ?1int?count?=?0;//记录条数 ?2string?strWhere?=?1=1; ?3if?(ViewState[reply]?!=?null) ?4{ ?5???string?keyWords?=?txtKey.Text.Trim().ToString();//查询关键字 ?6???strWhere?+=?Reply_Title?LIKE?‘%?+?keyWords?+?%’?+?OR?Reply_PostAuthor?LIKE?‘%?+?keyWords?+?%’; ?7}//查询 ?8 ?9GridDocReply.DataSource?=?bllDocReply.GetModelList(); 10GridDocReply.DataBind(); 11count?=?bllDocReply.GetModelList(strWhere); 近两年Web开发界盛行页面重构,是时候了,代码也要重构。 模块内代码简写及规范原则有以下几点: 1、使用三元运算符代替简单的if{…}else{…}(据说三元运算符效率稍低下,但在软件工程中讲代价值得的); 2、冗长的else可考虑使用switch(){case:…}代替,增强可读性; 3、静态数字常量最好开始以变量形式定义并做好注释; 4、频繁使用的变量可考虑将其归为属性成员 模块间代码优化是我一直在探索的, 软件开

文档评论(0)

80219pm + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档