前期如何设计后期才能更易于扩展和维护

谁学逆向工程 2016-08-09 11:25:00
关于这个话题,是不是要看设计模式和重构方面的书,有什么好的给推荐一下
...全文
159 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
ooolinux 2016-08-09
  • 打赏
  • 举报
回复
老赵是BASIC出身的
赵4老师 2016-08-09
  • 打赏
  • 举报
回复
炒了8年的概念,到底该如何理解DevOps这个词? http://www.primeton.com/read.php?id=2240&his=1 这个世界上唯一不变的就是变化。要拥抱变化。 请牢记:源代码本身的书写是否结构化或面向对象或符合设计模式或敏捷…并不重要,重要的是你是否使用结构化或面向对象或符合设计模式或敏捷…的方法命名标识符、阅读、修改、检查、测试源代码。 意思是你程序结构看上去再合理,再简洁,也不一定比看上去一团乱麻的程序结构在运行或修改时更不易出错,更方便修改,出错了更容易找到哪里出错和具体出错的原因,更容易改正错误。 试对比 图书馆(对图书的分类够结构化了吧) 和 搜索引擎(可看作是扁平化任何结构数据,仅支持全文检索) 哪个处理信息更方便、更高效。 所以 与其费劲去重构代码让其看上去更简洁、更合理 不如费劲学习grep、sed、awk、……这类全文搜索和批处理编辑的工具。 结构越复杂,越难修改,越难除错。 有时(甚至大多数时候),看上去越合理、越简洁的代码,运行起来性能越差,出错时查找原因越难,找到出错原因后改正越费劲。 程序员要做的不是尽力避免错误,而是聚焦在快速发现并改正错误。真正以快速方式轻易解决错误,“快速的失败”远胜过“预防错误”。Fred George 前微软C#编辑器的开发主管Jay Bazuzi列出的一些有助于找到正确方向的问题;他觉得前同事们应该用这些问题来问自己;实际上不管在哪里工作的开发者们都应该经常问问自己这些问题: ◆“要保证这个问题不会再出现,我该怎么做?” ◆“要想少出些Bug,我该怎么做?” ◆“要保证Bug容易被修复,我该怎么做?” ◆“要保持对变化的快速响应,我该怎么做?” ◆“要保证我的软件的运行速度,我该怎么做?” 如果大多数团队都能不时问一下自己,必定会从中得益,因为这些都是真正强而有力的问题。
列子汤问 2016-08-09
  • 打赏
  • 举报
回复
引用 楼主 xiaoyuanyuan2009 的回复:
关于这个话题,是不是要看设计模式和重构方面的书,有什么好的给推荐一下
我觉得是尽可能的解耦,但是分层太多了,也是累的。 还是要看具体业务了,要对业务很熟悉,大致知道哪些业务会在哪个方向有扩展。 细节方面不知道,但是方向性或许可以命中一些吧。
ooolinux 2016-08-09
  • 打赏
  • 举报
回复
引用 3 楼 xiaoyuanyuan2009 的回复:
引用 2 楼 u010165006 的回复:
老赵是BASIC出身的
面向过程的?
早期BASIC连结构化都没有,goto来goto去的。
赵4老师 2016-08-09
  • 打赏
  • 举报
回复
面向对象只是一种编程思想。 再抽象的编程语言,最后不都变成汇编代码了吗?我们完全可以说汇编语言是面向对象、脚本化、动态化、泛函化、并行化、分布化的语言。
  • 打赏
  • 举报
回复
考虑各种可能的扩充+设计模式
谁学逆向工程 2016-08-09
  • 打赏
  • 举报
回复
引用 2 楼 u010165006 的回复:
老赵是BASIC出身的
面向过程的?

15,440

社区成员

发帖
与我相关
我的任务
社区描述
C/C++ 非技术区
社区管理员
  • 非技术区社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧