做软件开发如何使自己的程序能适应多变的需求?
做软件开发如何使自己的程序能适应多变的需求?
[解决办法]
不要把自己的程序写得太死,灵活一些,比如说通过设置配置文件就可以改变软件的某项功能!
[解决办法]
同楼上,通过配置文件
[解决办法]
反对配置文件。
适应能力低是设计的问题。
[解决办法]
把需求当成职业
[解决办法]
在架构上关注对“可修改性”质量属性的支持。
可修改性的性能评价指标:在变更请求到来时,拥有合格可修改性的软件可以在时间与预算内完成修改。
可修改性战术:
1.局部化修改:维持语义的一致性;预期期望的变更;泛化该模块;限制可能的选择;抽象通用服务。
2.防止连锁反应:信息隐藏;维持现有接口(通过添加接口、添加适配器、预先提供占位符等方式);限制模块间的通信路径;使用仲裁者。
3.推迟绑定时间:运行时注册;使用配置文件;利用多态;组件更换;遵守行业协议。
以上摘自个人笔记,原书为《软件构架实践》。
[解决办法]
哈哈,这个问题太经典了,这是所有做管理信息系统的人都最想解决的问题。
以下是我的解决思路
1、前期尽量完善需求,一定要明确客户要达到的目的
2、开发业务开发平台,使管理信息系统中大部分数据维护操作的修改成本降到最低
3、通过商务手段,提高需求变更的成本
4、采用迭代开发方式,在开发过程多接触客户,尽量提早获知需求变更
5、通过培训让客户明白你提供的实现方式比他想到的要好,你是专业的。
[解决办法]
建议LZ不要把这个作为目标来追求。
原则上讲,软件能满足用户需求就OK了,再多做,实际上是不会有人买单的。如果要多做点前瞻性的功能进去,那也一定是因为有潜在的用户需求。
为什么觉得需求老是要变,根子是因为软件工程师不能准确地理解需求导致的。如果LZ有兴趣,建议去了解一下如何做细分市场方面的知识,这个有助于帮助你准确地去把握(细分市场的)用户需求。