社区
研发管理
帖子详情
请教有开发经验的高手
kelvingu616
2010-10-20 12:26:19
我们现在的项目的软件经过几个项目的开发,不断在原项目框架上通过打补丁添加新功能,使得结构很复杂,耦合度很高。
考虑过重构,但由于没有完整的需求和设计文档留下来,更没有测试文档和用例,使得我们不知如何下手。请教高手有什么办法呢?
...全文
163
26
打赏
收藏
请教有开发经验的高手
我们现在的项目的软件经过几个项目的开发,不断在原项目框架上通过打补丁添加新功能,使得结构很复杂,耦合度很高。 考虑过重构,但由于没有完整的需求和设计文档留下来,更没有测试文档和用例,使得我们不知如何下手。请教高手有什么办法呢?
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用AI写文章
26 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
kelvingu616
2011-01-10
打赏
举报
回复
[Quote=引用 7 楼 sp1234 的回复:]
引用 5 楼 kelvingu616 的回复:
引用 4 楼 worcy_kiddy 的回复:
你们软件本身架构就是不好,而且做得比较混乱,只能做下次项目时注意这些事情,你们开发人员可以把自己负责的模块重构一下!但是至少项目的相关文档需要补全吧?这些都没有,也太。。。。。。
同意您的观点,把文档补全无论对现在项目还是以后的开发都有好处
这是片面的。只有当项目基本上一年……
[/Quote]
对,我们现在就是慢慢写测试来进行。
文档的事情,可以说不够敏捷,也可以说是因为我们太懒了,就先不写了=0=
eagleatustb
2011-01-04
打赏
举报
回复
[Quote=引用 7 楼 sp1234 的回复:]
引用 5 楼 kelvingu616 的回复:
引用 4 楼 worcy_kiddy 的回复:
你们软件本身架构就是不好,而且做得比较混乱,只能做下次项目时注意这些事情,你们开发人员可以把自己负责的模块重构一下!但是至少项目的相关文档需要补全吧?这些都没有,也太。。。。。。
同意您的观点,把文档补全无论对现在项目还是以后的开发都有好处
这是片面的。只有当项目基本上一年不……
[/Quote]
我也碰到这样的问题,原来的程序很乱,改了这个发现另个一个又不行了,改了几次就不敢改了,现在准备做到自动化出来以后才真正着手重构。建议楼主参考这个!
ZSY2012
2010-12-30
打赏
举报
回复
由于没有相关需求和设计文档,要想重构大概要多劳神费力些了。我以前也碰到过这样没有文档、又很错综复杂的项目。那时是这样做的,第一步,当然要理解原来的程序,以大的结构方面为主,理清其关系(特别是控制关系等)。第二步,梳理其总的结构及其控制关系,与子系统结合紧密的尽量解耦到各个子系统中。第三步,逐步吃掉各个子系统,理清它们内部以及在此基础上它们之间的关系(或裁或增,或拆或合,或升或降等)。在整个处理过程中,为稳妥起见,原来的内容保留以备参考,但与新的内容并举,即重新构建一段路,在碰到问题时可以随即切换到原来的部分看看二者的异同以便找出新内容的问题;在新的部分运行稳定后可以干净地去掉原来的。不知于你有没有用,编程快乐。
cnyining
2010-12-28
打赏
举报
回复
我觉得代码也是文档。
一般可以这样干:
先搞明白业务,再把代码的结构关系理清楚,加入一些必要的注释;
最后,根据代码、业务等,决定如何重构;重构包括代码级的、系统级的。
我是一道光_
2010-12-07
打赏
举报
回复
我也在看代码,很少注释的代码。
的确要是逻辑复杂了,肯定乱七八糟的,扯东扯西
cwzmb
2010-12-07
打赏
举报
回复
[Quote=引用 19 楼 worcy_kiddy 的回复:]
引用 14 楼 cwzmb 的回复:
我以前有过类似的经验不知道适不适合你。
当初我们做了个视频传输client,不是我做的。
因为该Client在广域网上传输有马赛克,估计是丢帧导致,客户急需解决这BUG。
但做该Client的那个程序员已经辞职,他的代码也写的很乱,我们已经投入几个人员想尝试去看懂他的代码,还是无所获!因为实在看不懂,花了1个月也解决不了问题。
最后我提出一个方案,……
[/Quote]
抱歉我写的有点模糊,这一个月包括看他的程序,然后猜测在哪个地方出错,然后修改,没解决问题,又继续看他的代码,如此循环!花了一个多月没把BUG解了。而且,其实他的代码还是没有完全看懂。
我是一道光_
2010-12-05
打赏
举报
回复
[Quote=引用 14 楼 cwzmb 的回复:]
我以前有过类似的经验不知道适不适合你。
当初我们做了个视频传输client,不是我做的。
因为该Client在广域网上传输有马赛克,估计是丢帧导致,客户急需解决这BUG。
但做该Client的那个程序员已经辞职,他的代码也写的很乱,我们已经投入几个人员想尝试去看懂他的代码,还是无所获!因为实在看不懂,花了1个月也解决不了问题。
最后我提出一个方案,终于在两个星期内解掉该BUG。
那就是重……
[/Quote]
替换关键模块。
倒也可行。能复用的复用
黑泡泡选手
2010-12-04
打赏
举报
回复
[Quote=引用 14 楼 cwzmb 的回复:]
我以前有过类似的经验不知道适不适合你。
当初我们做了个视频传输client,不是我做的。
因为该Client在广域网上传输有马赛克,估计是丢帧导致,客户急需解决这BUG。
但做该Client的那个程序员已经辞职,他的代码也写的很乱,我们已经投入几个人员想尝试去看懂他的代码,还是无所获!因为实在看不懂,花了1个月也解决不了问题。
最后我提出一个方案,终于在两个星期内解掉该BUG。
那就是重……
[/Quote]
看了一个月都没看懂?那家伙写得什么程序?那惨了!
showerXP
2010-12-04
打赏
举报
回复
基本不能改。
能不能改,很大程度上看你设计时候抽象的结果。
yuxh81
2010-12-01
打赏
举报
回复
[Quote=引用 14 楼 cwzmb 的回复:]
我以前有过类似的经验不知道适不适合你。
当初我们做了个视频传输client,不是我做的。
因为该Client在广域网上传输有马赛克,估计是丢帧导致,客户急需解决这BUG。
但做该Client的那个程序员已经辞职,他的代码也写的很乱,我们已经投入几个人员想尝试去看懂他的代码,还是无所获!因为实在看不懂,花了1个月也解决不了问题。
最后我提出一个方案,终于在两个星期内解掉该BUG。
那就是……
[/Quote]
UP
Pro_X
2010-12-01
打赏
举报
回复
如果软件系统的模块数量超过一定程度,几乎无解.
archonwang111
2010-12-01
打赏
举报
回复
重构吧。这个工作比较吃力点。
cwzmb
2010-11-29
打赏
举报
回复
我以前有过类似的经验不知道适不适合你。
当初我们做了个视频传输client,不是我做的。
因为该Client在广域网上传输有马赛克,估计是丢帧导致,客户急需解决这BUG。
但做该Client的那个程序员已经辞职,他的代码也写的很乱,我们已经投入几个人员想尝试去看懂他的代码,还是无所获!因为实在看不懂,花了1个月也解决不了问题。
最后我提出一个方案,终于在两个星期内解掉该BUG。
那就是重新编写一个视频传输的模块,做成DLL,然后把原有程序的相关代码替换成调用该DLL。
所以,我认为你是否可以也这样做,对实在很乱没法看得懂的模块重新实现,替代掉原先的;
对不乱的稍微有点不合理的模块,进行修改;对已经很好的模块,保留!
每修改或重新实现一个模块,要对应产生相应的概要文档,没必要写那么详细。
jiaorg
2010-11-03
打赏
举报
回复
第一步,现在开始写文档
第二部、可以逐个逐个模块的重构吧,
kelvingu616
2010-11-03
打赏
举报
回复
现在我们是想进行自动化测试。
但测试是要基于设计文档,才能清楚函数、模块的意图。
现在苦于没有这些文档,测试很能进行。
我是一道光_
2010-10-31
打赏
举报
回复
[Quote=引用 10 楼 worcy_kiddy 的回复:]
引用 7 楼 sp1234 的回复:
引用 5 楼 kelvingu616 的回复:
引用 4 楼 worcy_kiddy 的回复:
你们软件本身架构就是不好,而且做得比较混乱,只能做下次项目时注意这些事情,你们开发人员可以把自己负责的模块重构一下!但是至少项目的相关文档需要补全吧?这些都没有,也太。。。。。。
同意您的观点,把文档补全无论对现在项目还是以后的开发都有好处
……
[/Quote]
哎,这样讨论都只是建立在如果的基础上。
额。 推倒重来不行,重做的话又要纠结于很多东西,难以抉择呀。
加油馒头
2010-10-28
打赏
举报
回复
后面增加开发时,尽量多注意些,从耦合度,关联度方面
黑泡泡选手
2010-10-28
打赏
举报
回复
[Quote=引用 7 楼 sp1234 的回复:]
引用 5 楼 kelvingu616 的回复:
引用 4 楼 worcy_kiddy 的回复:
你们软件本身架构就是不好,而且做得比较混乱,只能做下次项目时注意这些事情,你们开发人员可以把自己负责的模块重构一下!但是至少项目的相关文档需要补全吧?这些都没有,也太。。。。。。
同意您的观点,把文档补全无论对现在项目还是以后的开发都有好处
这是片面的。只有当项目基本上一年不……
[/Quote]
嗯,你说得很对,敏捷开发(迭代)使用自动化测试非常得有用,但是有没有意识做,有没有能力做,还是一个问号!
以专业开发人员为伍
2010-10-28
打赏
举报
回复
如果不懂自动测试,那么维护一堆这样生成的代码之后还要补充更多垃圾文档,就注定完蛋了。
以专业开发人员为伍
2010-10-28
打赏
举报
回复
[Quote=引用 5 楼 kelvingu616 的回复:]
引用 4 楼 worcy_kiddy 的回复:
你们软件本身架构就是不好,而且做得比较混乱,只能做下次项目时注意这些事情,你们开发人员可以把自己负责的模块重构一下!但是至少项目的相关文档需要补全吧?这些都没有,也太。。。。。。
同意您的观点,把文档补全无论对现在项目还是以后的开发都有好处
[/Quote]
这是片面的。只有当项目基本上一年不改动时才有必要慢慢纠结文档。而如果要求比较敏捷,则应该补充几百个自动化测试,这样在任何变化和增加测试时都会因为必须严格的自动测试强度而发现架构(这样才敢于重构),而不是空洞的文档。
加载更多回复(6)
生辰八字计算卦相查询源码
计算生辰八字源码,很全,完全自主
开发
,找了好多计算生辰八字的源码都不完整,把所有分都花光了,后来自己
请教
相关
高手
点拨
开发
出来的算命软件。下载内容包括计算生辰八字全部源码及生辰八字计算运行程序。别嫌弃资源分高,绝对物有所值!
菜鸟
请教
高手
web
开发
内存问题?
为什么80%的码农都做不了架构师?>>> ...
我想
请教
各位
高手
一个问题!
我想
请教
各位
高手
一个问题,我用的是.net2003智能化手持的
开发
。 在调用服务程序时(用winform写的)开始时是正常的,可是没调两次就会出现一个异常,而不能再调用服务程序上的函数,异常中出现的错误如下: 未处理的“System.Net.WebException”类型的异常出现在System.Web.Services.dll中。其他信息:无法找到资源程序集请各位
高手
帮帮忙,急用啊!谢谢了!
如何快速
开发
LabVIEW项目,成为LabVIEW
开发
的
高手
原来,他们公司请的国内某顶尖高校的一个博士硕士团队,给他
开发
的程序,(其实,就是导师成立的血汗公司),这些人对LabVIEW不是很精通,又由于责任心的问题(学生到时候就毕业走人哦,老板的重心不在售后服务上,说白了不就那么回事嘛,导师正忙着跑项目赚钱呢。其实,国内,尤其是在北京大家可以去北京辰语测控www.bjcyck.com学习培训,可以从最基础入手学习,这家公司也承担
开发
外包业务,你也可以在产品外包给他们后,在
开发
过程中一起去做,这样在做中学,在学中做,如有问题可以及时
请教
,效果还是非常不错的。
向各位
高手
请教
,我想成为一名专注
开发
网站的的程序员希望有人能指点一二
本人一名大学生。一心想成为程序员,向各位
高手
请教
,我想成为一名专注
开发
网站的的程序员希望有人能指点一二 !
研发管理
1,268
社区成员
28,284
社区内容
发帖
与我相关
我的任务
研发管理
软件工程/管理 管理版
复制链接
扫一扫
分享
社区描述
软件工程/管理 管理版
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章