`
poson
  • 浏览: 364293 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

你们的项目经常重构代码吗?

阅读更多
我们的代码,经常都有代码review。但是代码review之后,大家并没有大量的重构代码。主要原因是重构代码需要花太多的时间,而且还有再次测试,对于很少的项目时间来说,重构代码是很不划算的。

不过不重构代码,大家的代码质量又很难提高。不知道大家怎么办?
分享到:
评论
56 楼 tuti 2010-02-26  
Durian 写道
1.反对TDD开发,太浪费时间,平时可以自己多做点黑盒,白合测试什么都有了。
2.适当的重构,不建议太大改动,测试成本太高。


TDD太浪费时间?你是和什么比浪费时间?和Debug比?和你的黑箱,白箱测试比?
既然你那么能省时间,何必感叹代码改动还测试成本高?
55 楼 lkj107 2010-02-26  
上线的系统重构风险太大,一般是忽悠上二期的时候推倒重来
54 楼 poson 2009-12-26  
1.反对TDD开发,太浪费时间,平时可以自己多做点黑盒,白合测试什么都有了。
2.适当的重构,不建议太大改动,测试成本太高。
Durian 写道
1.反对TDD开发,太浪费时间,平时可以自己多做点黑盒,白合测试什么都有了。
2.适当的重构,不建议太大改动,测试成本太高。


确实是测试成本很高。别人帮我重构了代码,测试的时候发现一大堆问题。
不过自己经常重构,确实可以提高自己的编码水平。
53 楼 Durian 2009-12-21  
1.反对TDD开发,太浪费时间,平时可以自己多做点黑盒,白合测试什么都有了。
2.适当的重构,不建议太大改动,测试成本太高。
52 楼 xinnn 2009-09-16  
重构代码是分层次和级别的,一般来说会有代码级的重构、模块级的重构和系统级的重构。
按照你的说法,你们的重构起码是模块级以上的了,如果是这样的话问题可能就会比较多了,很大一部分原因是系统模块的设计问题了,如果设计的兼容性比较差的话是会导致需要不断的做重构来适应需求的不断变化,而好的设计人员往往会提前在设计之时考虑到相关会涉及到的问题从而在设计方案中为潜在的问题和需求预留好解决的接口,不会导致系统出现大的改动,更不会有颠覆性的重构现象。
代码级的重构在功能实现之时就要自己来对涉及性能和复杂逻辑等问题进行代码重构了,而review的一个很重要的一点就是大家相互之间提出对代码的编写意见,其实质就是相互之间提出代码的重构意见。
总之,重构在项目质量的问题上时很重要的一环,具体来说重构在项目中的比重到底应该占多少,应该视对项目质量的比重而定,比如对时间比较紧的项目就可适当减少重构的比重。我曾做过连测试都没有就发布的项目,更不要说重构了,最要紧的问题是项目允许你的时间不够了。而重构代码绝对对你的代码编写能力的提高有帮助
51 楼 ldd600 2009-08-04  
遗留代码很难重构吧,只有在fix问题的时候,适当的重构,加入相关的单元测试。即使做新的cr,也不会对遗留代码中相关部分进行大规模重构,老大们的意思一般都是不出问题,就不要去改它。
50 楼 icewubin 2009-08-03  
pipilu 写道
楼上说的那件事儿挺逗,笑死了。我觉得不提倡做删除操作,因为那个文件一删,那以前的修改记录就无迹可循了。

SVN上文件如果是重构改名字导致的删除的话,历史都是保留的,跟着重构以后的文件走。

CVS不支持这个功能。

还有就是,真的是删除操作的话,之前的修改记录是找的回来的,就是比较麻烦而已。

49 楼 rocwon 2009-07-31  
要想把代码写好的话,重构无处不在
48 楼 liusu 2009-07-24  
看这个讨论,才发现我已经步入重构强迫症的行列。 我是写几行代码就不舒服就想重构。方法命名,变量命名让我很纠结。是不是需要泛型,是不是要提个接口。。 哈哈
47 楼 chxkyy 2009-07-09  
如果是web页面,怎么做测试?手工点?
46 楼 tibetjungle 2009-07-08  
rappy 写道

其实,只要经过前期详细分析和设计,做好设计工作,中期在代码开发中坚决实施TDD,完全可以控制这种风险。



这样做,你完全可以开发一个新的系统了。难道你没有意识到,在你给出的这个过程中,存在着重重风险吗?你去做分析,原始需求文档怎么保证?实现中,很多系统根本就没有任何文档,所有的文档都在早期开发者的脑袋里。而且即使有,你也难以保障你分析的结果是无误的,只要实际验证、使用时才会发现是否存在问题……

TDD不是万能的,而且其中隐含一个前提:你必须理解需求!

一句话,对于某些项目:do not fix it until it is broken.
45 楼 lcllcl987 2009-07-07  
我们经常号称在重构, 但干的却是重写的勾当。
我们的项目运行于乌托邦,所以可以这样。
哈哈

44 楼 rappy 2009-07-06  
mock1234 写道
不要把重构说成是一个重量级的企业开发文档开发步骤,那种理解是很荒唐的。XP的重构,是指发生在5~10分钟之内的那种操作,只有擅长每一次都高标准地完成看似短促、心血来潮就可以进行的重构才具有最大的威力,这个时候如果你的代码总是可以保持系统回归测试稳定性就可谓巅峰状态之作;而那些费了九牛二虎之力搞一场轰轰烈烈重构运动的笨重行为则反而不太擅长重构,初级水平、质量较低的开发人员就可以做这个事了。


这个说法有些偏激,尤其是最后一句。相反,这种大运动量的重构,更需要行家里手才行,否则,质量无法保证,重构等于空谈。

看了很多回复,大部分都排斥大规模的重构。但是,如果是针对老代码,老架构进行重构呢,这难道就不叫重构,就不能重构了?不然,而是缺少这样的魄力去做,没人敢冒这风险。其实,只要经过前期详细分析和设计,做好设计工作,中期在代码开发中坚决实施TDD,完全可以控制这种风险。

我理解的重构,关键不在量的多少,频度的多少,而是是否能在代码稳定性,健壮性,效率上有提升。

当然,频繁的小粒度的重构或许是种比较好的方式。
43 楼 seekgirl 2009-07-05  
呵呵,项目经理要是没有这个意思,啥也白搭
42 楼 tuti 2009-07-03  
eclipse2008 写道
是否重构那就要看性价比了。


重构在我看来是种看多代码需要变动的期权。
41 楼 eclipse2008 2009-07-02  
是否重构那就要看性价比了。
40 楼 gigix 2009-07-02  
pangyi 写道
tuti 写道
没自动测试,就不要扯什么重构。



没有自动化测试,就不能重构了吗?

不太合理吧。自动化测试与重构有必然关系吗?

Martin Fowler 写道
重构:在不改变代码可观察之行为的前提下修改代码结构以改善代码质量

没有自动化测试你怎么确保可观察的行为不改变?rename一下然后人肉回归所有功能?
39 楼 pangyi 2009-07-02  
tuti 写道
没自动测试,就不要扯什么重构。



没有自动化测试,就不能重构了吗?

不太合理吧。自动化测试与重构有必然关系吗?
38 楼 抛出异常的爱 2009-07-02  
seen 写道
抛出异常的爱 写道
gigix 写道
neptune 写道
注意:如果是大项目或长时间的项目,重构好。如果是小项目或一次的项目,不要冲动,重构是需要成本的。

然后等客户说“第一期做得不错呀,你们接着做第二期吧”的时候抓栏杆撕床单

如果不用TTD一般的需求是怎么记录的?
用buglist这种方式有点冗余.
需求说明书又缺很多需求变更.
实在是不知道作二期的那群人
是怎么把一期的需求
从代码中扒出来的?

上个项目最失败的几点都是由于需求扒出来的时候走了样



按你说法 需求难道应该用tdd来保存?

真的不知道用什么来保存
上家上上家都是用人脑来保存这些信息......
37 楼 daquan198163 2009-07-01  
抛出异常的爱 写道
gigix 写道
neptune 写道
注意:如果是大项目或长时间的项目,重构好。如果是小项目或一次的项目,不要冲动,重构是需要成本的。

然后等客户说“第一期做得不错呀,你们接着做第二期吧”的时候抓栏杆撕床单

如果不用TTD一般的需求是怎么记录的?
用buglist这种方式有点冗余.
需求说明书又缺很多需求变更.
实在是不知道作二期的那群人
是怎么把一期的需求
从代码中扒出来的?

上个项目最失败的几点都是由于需求扒出来的时候走了样

先出个需求说明书,然后分解成功能点或jira的task或用户故事或随便什么东西,
然后每次迭代实现一些功能,改一些bug,如此反复,直到没啥可做的了。
貌似跟tdd没啥关系。

相关推荐

    实战项目开发编码规范

    【编码规范】在IT项目开发中,编码规范扮演着至关重要的角色。...同时,规范的使用也有助于代码审查,自动化工具的使用,以及后期的重构工作。因此,对于团队开发项目,制定并执行编码规范是不可或缺的。

    va可以使用,大家请放心使用,谢谢你们

    Visual Assist(简称VA)是一款广泛应用于Visual Studio集成开发环境中的增强插件,它极大地提升了代码编写、导航和重构的效率。在标题和描述中提到的"va可以使用,大家请放心使用,谢谢你们,Visual Assist 10.9 -...

    matlab导入excel代码-MainPage:本项目是电子科技大学材料科协维护的资料集

    万分感谢每一位为本项目做出贡献的人员,后来者因你们的努力而站得更高,走得更远,也希望后来者能将这种分享、奉献、开源的伟大精神一代一代传承下去。 感谢每一位贡献者: 目录 嵌入式技术篇 学习路线 萌新入门 ...

    拉教老框框记

    9. **最佳实践**:在IT领域,有许多最佳实践,如单元测试、代码重构和设计模式等,这些都可能是文档的重点。 10. **资源管理**:包括如何管理数据库、服务器配置、云服务的使用,以及如何优化资源利用率。 尽管...

    pos-tdd-pair:和我的搭档 Liu HuiMin@knight4925 重做我的 pos 作业

    这表明你们重视代码的质量和可测试性,遵循“红色-绿色-重构”的TDD循环,即先写失败的测试(红色),然后编写使测试通过的最小代码(绿色),最后重构代码以提高可读性和维护性。 标签“JavaScript”说明了这个POS...

    flutter_wan:flutter版玩android,页面基本均是fish_redux搭建

    初版的fish_redux的玩Android是我刚学flutter时写的,代码写的比较混乱,重构代码,也是为了让大家更清晰了解fish_redux结构,也给出TabBar控制器在fish_redux初始化的解决方案,大家可以看看 重构的所有模块,无限...

    C和C++编程心得—前人的经验总结

    - 《重构:改善既有代码的设计》:这本书介绍了如何优化现有代码,提高软件质量。 - 《代码整洁之道》:这本书介绍了编写干净、易于维护的代码的原则和实践。 **找书的诀窍** - 在线书店:亚马逊、当当网等提供...

    Silverlight在线几何绘图

    当你解读Silverlight代码和WPF代码的时候,你将会发现这并没有什么重大的不同之处(所以现在出现了Silverlight 和 WPF的兼容性类库,甚至出现了Silverlight 和 WPF的转换程序)。或者我们不妨悲剧的理解这本就是一个...

    PIC CMS图片网站管理系统 v1.2.ZIP

    前后端界面也全面重构,更加简洁,规范和易用。开放全部源代码,并保留所有注释,可以在遵循开源协议的前提下,方便的进行二次开发,甚至可以基于术框架构架一个全新的系统,我们将来会提供详细的API文档。 1.最快捷,最...

Global site tag (gtag.js) - Google Analytics