`

软件架构含义及其总结

 
阅读更多
软件架构的含义:
架构师必须做出许多设计决定。要想有用,这些决定必须用文档记录下来,这样就能够进行复审、讨论、修改和批准,然后作为后续决定和构建时的约束。

创建软件架构:
软件架构师的首要关注点不是系统的功能。你关注的是需要满足的品质。品质关注点指明了功能必须以何种方式交付,才能被系统的利益相关人所接受,系统的结果包含这些人的既定利益。
成功架构师的两项关键实践:让利益相关人参与以及同时关注功能和品质。作为一名架构师,你首先问我们想从系统中得到什么,有怎样的优先级。在实际项目中,你会找出其他的利益相关人。
考虑折中实现。

架构结构:
 架构师的主要关注点就是对系统进行组织,让每种结构有助于解答一个关注点所定义的问题

架构师玩的是折中的游戏
提供场景分析,。架构师然解释该架构如何支持每一种场景

好的代码要很容易让新手上手,每段代码风格统一。

架构步骤:
1.我们确定了主要的功能领域
2.我们在系统的核心上花了额外的设计时间
3.故事展开:设计和编码要么以结对的方式完成,要么经过仔细的复审,确保工作的正确性
4.如果你不是马上需要,就不要去做
5.保持品质
从一开始,“设计之城”就准备好了一些品质控制过程:
• 结对编程。
• 对没有结对编程的工作进行代码/设计复审。
• 对每一段代码进行单元测试。
6.管理技术债务
小的代码“瑕疵”或设计问题允许存在于代码集中,要么是为了让功能快一点实现,要么是为了在接近发布时避免高风险的改动,这些逃避职责的地方被标记为技术债务,并安排在后续的版本发布中修正。这些问题很清楚,开发者对它们不满意,直到将它们处理掉为止。同样,我们看到了开发者对设计的品质负责


总结:
确实进行有意为之的前端设计。(许多项目甚至还没开始,就因为这一点而失败了。)
• 设计者的素质和经验。(以前犯过一些错误是有帮助的,这能在下一次为你指出正的方向)
• 在开发过程中,保持清晰的设计观点。
• 授权团队负责软件的整体设计,而团队也承担起这一责任。
• 不要害怕改变设计:没有什么是一成不变的。
• 让合适的人加入到团队中,包括设计者、程序员和经理,确保开发团队的规模合适。确保他们具有健康的工作关系,因为这些关系将不可避免地影响代码的结构。
• 在合适的时候做出设计决定,当你知道所有必要信息时再做出决定。延迟那些暂时不能做出的决定。
• 好的项目管理过程,需要定一个合适的最后期限。
分享到:
评论
2 楼 sybase001 2012-03-31  
顶  一  个
1 楼 zfms 2012-03-31  

架构步骤:
1.我们确定了主要的功能领域
2.我们在系统的核心上花了额外的设计时间
3.故事展开:设计和编码要么以结对的方式完成,要么经过仔细的复审,确保工作的正确性
4.如果你不是马上需要,就不要去做
5.保持品质
从一开始,“设计之城”就准备好了一些品质控制过程:
• 结对编程。
• 对没有结对编程的工作进行代码/设计复审。
• 对每一段代码进行单元测试。
6.管理技术债务
小的代码“瑕疵”或设计问题允许存在于代码集中,要么是为了让功能快一点实现,要么是为了在接近发布时避免高风险的改动,这些逃避职责的地方被标记为技术债务,并安排在后续的版本发布中修正。这些问题很清楚,开发者对它们不满意,直到将它们处理掉为止。同样,我们看到了开发者对设计的品质负责


总结:
确实进行有意为之的前端设计。(许多项目甚至还没开始,就因为这一点而失败了。)
• 设计者的素质和经验。(以前犯过一些错误是有帮助的,这能在下一次为你指出正的方向)
• 在开发过程中,保持清晰的设计观点。
• 授权团队负责软件的整体设计,而团队也承担起这一责任。
• 不要害怕改变设计:没有什么是一成不变的。
• 让合适的人加入到团队中,包括设计者、程序员和经理,确保开发团队的规模合适。确保他们具有健康的工作关系,因为这些关系将不可避免地影响代码的结构。
• 在合适的时候做出设计决定,当你知道所有必要信息时再做出决定。延迟那些暂时不能做出的决定。
• 好的项目管理过程,需要定一个合适的最后期限。

相关推荐

    UML和模式应用(架构师必备).part06.rar

    13.4 什么是软件架构 13.5 应用UML:包图 13.6 准则:使用层进行设计 13.7 准则:模型-视图分离原则 13.8 SSD、系统操作和层之间的联系 13.9 示例:NextGen的逻辑架构和包图 13.10 示例:Monopoly逻辑架构 ...

    软件测试必看 入门级的教程

    15.2 软件黑盒测试常见错误类型及说明 81 15.2.1 用户界面错误 81 15.2.2 功能性 81 15.2.3 人机交互 82 15.3 命令结构和录入 87 15.3.1 不一致性 87 15.3.2 “最优化” 87 15.3.3 菜单 89 15.4 遗漏...

    软件工程-08-设计优化.pptx

    高质量的建模要以简单和小为基本观点,从方法级开始,逐渐过渡到组件、架构及更高级别的组织策略,对设计原则进行体现。 软件模式是在开发实践中针对经常发生问题的相同或相似解决方案,是设计经验的总结与重用。 ...

    UML和模式应用(架构师必备).part01.rar

    13.4 什么是软件架构 13.5 应用UML:包图 13.6 准则:使用层进行设计 13.7 准则:模型-视图分离原则 13.8 SSD、系统操作和层之间的联系 13.9 示例:NextGen的逻辑架构和包图 13.10 示例:Monopoly逻辑架构 ...

    UML和模式应用(架构师必备).part07.rar

    13.4 什么是软件架构 13.5 应用UML:包图 13.6 准则:使用层进行设计 13.7 准则:模型-视图分离原则 13.8 SSD、系统操作和层之间的联系 13.9 示例:NextGen的逻辑架构和包图 13.10 示例:Monopoly逻辑架构 ...

    UML和模式应用(架构师必备).part02.rar

    13.4 什么是软件架构 13.5 应用UML:包图 13.6 准则:使用层进行设计 13.7 准则:模型-视图分离原则 13.8 SSD、系统操作和层之间的联系 13.9 示例:NextGen的逻辑架构和包图 13.10 示例:Monopoly逻辑架构 ...

    UML和模式应用(架构师必备).part03.rar

    13.4 什么是软件架构 13.5 应用UML:包图 13.6 准则:使用层进行设计 13.7 准则:模型-视图分离原则 13.8 SSD、系统操作和层之间的联系 13.9 示例:NextGen的逻辑架构和包图 13.10 示例:Monopoly逻辑架构 ...

    UML和模式应用(架构师必备).part04.rar

    13.4 什么是软件架构 13.5 应用UML:包图 13.6 准则:使用层进行设计 13.7 准则:模型-视图分离原则 13.8 SSD、系统操作和层之间的联系 13.9 示例:NextGen的逻辑架构和包图 13.10 示例:Monopoly逻辑架构 ...

    UML和模式应用(架构师必备).part05.rar

    13.4 什么是软件架构 13.5 应用UML:包图 13.6 准则:使用层进行设计 13.7 准则:模型-视图分离原则 13.8 SSD、系统操作和层之间的联系 13.9 示例:NextGen的逻辑架构和包图 13.10 示例:Monopoly逻辑架构 ...

    UML和模式应用(架构师必备).part08.rar

    13.4 什么是软件架构 13.5 应用UML:包图 13.6 准则:使用层进行设计 13.7 准则:模型-视图分离原则 13.8 SSD、系统操作和层之间的联系 13.9 示例:NextGen的逻辑架构和包图 13.10 示例:Monopoly逻辑架构 ...

    软件测试入门(必看)

    15.2 软件黑盒测试常见错误类型及说明 81 15.2.1 用户界面错误 81 15.2.2 功能性 81 15.2.3 人机交互 82 15.3 命令结构和录入 87 15.3.1 不一致性 87 15.3.2 “最优化” 87 15.3.3 菜单 89 15.4 遗漏...

    程序开发原理:抽象、规格与面向对象设计.[美]Barbara Liskov(带详细书签).pdf

    书中讨论了怎样构建具有高可靠性、易于维护和快速修改的软件的开发方法,强调了软件的模块化开发思想,用丰富的实例告诉读者怎样进行模块化并合理地组织各种模块以构成大型软件系统的过程。该书的前8章首次提出编程...

    Dialogic从入门到系统工程师_完整版

    6.4.1 Dialogic软件系统架构及开发接口 161 第七章 了解Dialogic SRL 164 7.1 SRL术语表 164 7.2 SRL里有什么 164 7.3 静态连接 165 7.4 运行时链接 165 7.5 SRL事件管理 167 7.6 SRL用户数据管理 168 7.7 ...

    产品经理学习视频

    02.第二阶段:产品经理的工作方法及应用 1产品经理原型设计工具Axure使用基础 1-认识Axure.mp4 2-Axure操作界面.mp4 3-动态面板.mp4 4-创建部件库.mp4 5-交互设置.mp4 6-变量.mp4 7-Web案例1.mp4 8-Web案例...

    C#微软培训资料

    C#语言在.NET 框架中的作用及其特性 1.1 Microsoft.NET 一场新的革命 1.1.1 什么是.NET 2000 年 6 月 22 日 不论对 Microsoft 还是对整个 IT 业界都将成为值得纪念的一天 这一天 微软公司正式推出...

    uboott移植实验手册及技术文档

    arm: CPU的架构(ARCH) arm920t: CPU的类型(CPU),其对应于 cpu/arm920t子目录。 fs2410: 开发板的型号(BOARD),对应于 board/fs2410目录。 NULL: 开发者/或经销商(vender),本例为空 s3c24x0: 片上系统(SOC) ...

    二十三种设计模式【PDF版】

    主要是介绍各种格式流行的软件设计模式,对于程序员的进一步提升起推进作用,有时间可以随便翻翻~~ 23种设计模式汇集 如果你还不了解设计模式是什么的话? 那就先看设计模式引言 ! 学习 GoF 设计模式的重要性 ...

    MySQLDBA运维笔记.pdf

    mysql 总结........................................................................................................................................6 1.1 数据库的种类.......................................

Global site tag (gtag.js) - Google Analytics