刘捷老师软件设计最佳实践和案例分析培训

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

软件设计最佳实践和案例分析培训课程简介:几十年来,软件开发实践一直被惊人的低成功率所困扰。作为软件设计师,你知道现在软件开发悲剧的根源在哪里吗?如果你连根源都不知道在哪里?你怎样知道去解决呢?在软件开发过程之中,会遇到各种各样的问题,原因归结起来主要根源有两个方面,一个是复杂性,一个是变化性。软件的规模越大,各个部分之间的牵连越复杂,更改也就越难。如果软件简单并且规模小,更改还比较容易。但是随着用户业务复杂,几乎所有的软件的任务规模都会越来越大。伴随着软件越来越复杂,对软件的变更需求越来越频繁,更改所需求的花费越来越大。我们软件开发人员的悲剧就诞生了。很多软件的设计往往是大泥球式的设计,指结构杂乱无章、错综复杂、邋遢不堪、随意拼贴的大堆代码。在现今软件开发日趋复杂的情况下,围绕着如何安排、规划这些活动的次序、周期和时间,人们提出过各种各样的软件开发方法模型。比如目前流行的敏捷/RUP等等.但是你真正知道吗?软件质量最终还是依赖较强责任心和能力的设计师。除非如此,不管是敏捷是非敏捷,软件设计的问题根本不能解决。因此持续关注优秀技能和良好的设计,才可以真正实现敏捷。我们大多在一线的设计师,不了解设计的基本原则/模式,但是可惜当他知道一些原则和模式后,却已经变成了管理者(项目经理,产品经理等管理岗位),不在从事设计的工作.这真是业界悲哀的事情.我们课程重点关注软件设计师技能,这是本课程的设置的目的.课程总结了多年项目开发的实战经验,让学员体会在软件系统设计过程中提高能力。【主办单位】中国电子标准协会【协办单位】深圳市威硕企业管理咨询有限公司课程体系结构:课程体系结构课程主题内容项目案例6个真实大型项目案例设计过程分析如何进行设计,权衡过程设计价值观不仅仅实现功能,关注设计质量属性(可维护性和复用)设计原则软件设计的基本原则设计模式常见架构/设计模式设计建模敏捷UML建模设计最佳实践设计的最佳实践课程特色:一般的书籍和培训,往往是介绍设计过程,设计原则和模式,之后再给出几个简单的在理想情况下的应用.要么是拿出最终设计来讲解,然后告诉他的设计的是多么灵活,多么的好.但是当你课程结束后,回到工作之中却发现情况是完全的不一样,这时你只有束手无策.本课程注重实战,采用案例贯穿方式完成讲解理论,让学员体验软件设计的思索,权衡,折中,选择的痛苦过程,首先提出真实项目的需求,然后学员开始动手设计,最终讲师和你一起思索,一起探讨,一起权衡,一起验证.学员学习本课程应具备下列基础知识:1)至少2年以上开发经验,经历过频繁需求变更或者系统重复开发的折磨2)熟悉Java/C#/C++任意一种面向对象语言或者具备面向对象编程基本概念3)一般软件企业的设计人员和初级架构师,以及资深程序员谁已经选择了该课程?我们已经为几十家企业提供了内训如Adobe中国研发中心,Autodesk软件(中国)研发中心,爱立信中国研发中心(7次内训),思科中国研发中心,卓望科技,朗讯研发中心,平安科技,Visto中国研发中心,横河电机(中国)有限公司,大唐电信研发中心,美国通用电气(GE)研发中心,迈瑞研发中心,阿里巴巴研发中心,摩托罗拉成都研发中心主题内容第一单元软件设计目标-灵活性/可插入性/可扩展内容一:拥抱需求变化---设计师必须面对的1、不管你在何处工作,构建些什么,用何种语言,在软件开发上,一直最痛苦的事情是什么?或者什么是你开发之中最讨厌的问题是什么?---需求变更2、杀死一个程序员不需要刀,只要需求变3次就好了!!3、软件不断变更法则:真实世界中使用的程序必须进行变更,否则它在环境中的作用就会越来越小.4、需求改变的态度-拒绝变化无用,积极心态面对变化5、而敏捷对预测未来的方式是全新的,强调通过提高团队的能力、设计的弹性和流程的灵活性来适应变化。这种思路对软件开发也是很大的冲击。6、软件设计的目标-灵活性,因为增加一个功能特性的成本并不单单是为这些功能编码所花费时间的成本,还应该包括特性扩展的障碍成本。现在我们遇到的最大障碍是现在系统的混乱,难以扩展。7、案例分析—通过案例分析需要变化的根源,以及各种情况第二单元如何设计才能实现灵活性内容一:软件设计的灵活性1、什么是好的设计和衡量的手段,世界大师的观点(RobertCMartin,PeterCode,`JamesShor)2、一个好的系统设计应该有如下的性质:可扩展性、灵活性、可插入性。-PeterCode[CODE99]3、可扩展性(Extensibility)容易添加新的功能.结合案例,通过那些手段如何实现该目标4、灵活性(Flexibility)代码修改平稳地发生.结合案例,通过那些手段如何实现该目标5、可插入性(Pluggability)容易将一个类抽出去,同时将另一个有同样接口的类加入进来.结合案例,通过那些手段如何实现该目标6、分析真实项目,如何做的详细设计,给我们哪些启示,我们可以学习到什么7、分析我们在项目之中是那些原因导致了没有实现这些目标.内容二:案例-某项目认证管理模块设计案例1、某省移动项目,必须考虑支持多种设备厂商2、初始设计的问题分析3、应用何种模式解决问题第三单元灵活性设计基本原则/模式/实践内容一:灵活设计的基本原则1、发现和封装变化的原则2、找出应用中可能需要变化之处,把它们独立出来,不要和那些不需要变化的代码交织在一起.3、抽象稳定接口(抽象类),针对接口编程,而不是针对实现编程4、分离变化维度,单一职责原则5、动态绑定还是静态绑定,多用组合,少用继承6、创建与使用分离,创建有变化也要封装7、结合多个案例项目进行分析,怎样发现和封装变化,如何通过具体的手段来进行适应这些变化内容二:灵活性设计的最佳实践1、多态(polymorphism)和针对接口的编程2、数据驱动(Data-DrivenDesign)3、元数据驱动设计4、反射驱动(Meta-dataorReflective)5、解释器驱动6、脚本引擎技术7、结合多个案例项目进行分析,怎样发现和封装变化,如何通过具体的手段来进行适应这些变化内容三:案例---结合案例分析软件设计原则/模式1、某项目系统的演变,以及设计原则的应用效果,通过项目的演化分析这些核心设计原则的应用场景2、通过一个大型实例,传递CleanCode,设计原则等,包括DIY原则,TellDon'tAsk原则,Soild原则(SingleResponsibility原则,OpenClosed原则,LiskovSubstitution原则,InterfaceSegregation原则,DependencyInversion原则)。3、案例分析-设计原则的应用第四单元软件设计腐化内容一:设计腐化与技术债务1、设计腐化的途经2、总结常见的设计腐化途经,原因及克服方法3、技术债务概述4、软件债务对软件系统的危害5、软件债务对软件开发人员的危害6、技术债务与破窗效应7、技术债务的解决之道8、通过案例分析,如何解决技术债务内容二:技术债务监控1、软件腐化监控2、国际著名某电信研发中心监控工具内容三:软件腐化与希波克拉底宣言1、First,DoNoHarm.首先,做到不伤害!—Hippocrates希波克拉底2、Proxy代理模式与软件修改方案3、decorator模式与遗留软件修改4、案例分析—如果维护遗留系统而不是遗留系统变烂内容四:案例-演示系统软件腐化的过程1、某电信研发中心项目系统2、初始设计的问题分析3、故障单管理系统4、流程审核的改变5、故障单类型的增加6、传统设计的问题与如何通过代码进行演化7、通过该案例分析,对比有时是因为人员的设计技能导致加速软件的腐化8、通过该案例分析,讲师加入项目之后,将进行哪些重构第五单元演化式设计内容一:演化式设计(EmergentDesign)1、演化式设计EmergentDesign2、演化设计--重构带来了一种新的构设计方法,称为反思性设计(ReflectiveDesign)。除了创建一种设计并用代码实现它之外,你现在还可以分析已有代码的设计并改善它。寻求改进的一种最好的方法是通过代码嗅觉(codesmells).3、在详细设计之中,如何对发现问题的设计进行重构4、很多公司习惯做大量的预习设计,这被证明是风险很高的做法。好的架构和设计是演进出来的,通过这个环节了解演进式设计的方法,包括演进式设计的方法、工具、模式等内容。包括如何计划重构活动以实现架构演进,如何从设计方法、技术债务、复杂性等角度看架构演进5、案例分析,根据课程介绍的坏症状,进行重构合理的设计内容二:设计的新认识—源代码就是设计1、传统代码认识的误区2、设计与施工分离的误区3、源代码就是设计4、分析真实项目代码,认识代码的重要性.垃圾代码的危害内容三:拙劣设计的坏症状和重构1、拙劣设计概述2、拙劣设计常见症状以及如何发现和治疗3、在详细设计之中,如何对发现问题的设计进行重构4、代码坏味道概述5、常见的重构设计方式6、重构到设计模式7、案例分析-对实际项目的案例进行代码分析和重构8、案例分析,根据课程介绍的坏症状,进行实际项目重构的设计内容四:案例---某零售项目系统分析1、零售租赁管理系统2、第一版本设计和评审3、故障单类型的增加4、传统设计的问题与如何通过代码进行演化第六单元关注人-设计师与技能的思考内容一:设计师与设计技能1、某研发团队5年前引入敏捷的失败教训-能力比方法重要,但改变方法比改变能力简单多了2、无论什么道什么术,什么方法或思想,离开了人都是虚妄。优秀的设计来自优秀的设计师,因此应该首先是尊重个体的主动和创造性,提高个体工作技能,而不是应用了一种流程,消灭了个体的活力。首先关注人,才能真敏捷。3、案例分析,某研发中心引入敏捷的实战分析,什么才是真正的敏捷。内容二:设计师能力模型1、设计能力金字塔2、软件设计价值观3、软件设计原则4、软件设计模式5、软件设计最佳实践6、通过某研发中心的设计师能力模型分析,设计能力提升计划第七单元软件设计复用性内容一:软件复用设计1、在详细设计之中,分析发现共同的行为的抽象和共同的机制来实现2、软件通用服务组件的设计3、复用已有的东西,比自己编写更容易。如果不容易,大家就不会去复用。4、软件复用的管理策略5、对象级别复用6、模块级别复用7、架构层次复用8、软件复用之道9、案例分析复用的设计之道内容二:某电信项目案例-异常处理框架设计1、系统的异常处理策略2、设计一个通用异常处理子系统3、分析如何应用设计模式在该案例4、分析通过应用设计模式,带来了哪些好处(表现在软件的灵活性)5、分析如何转换为Framework6、典型案例分析:该框架已经在多个大型项目之中应用第八单元软件设计案例分析内容一:大型软件项目设计案例分析-案例分析结合以上章节1、某电信核心系统设计最佳实践和案例分析2、某电力系统设计最佳实践和案例分析3、某Web互联网电子商务系统设计最佳实践和案例分析4、某税务系统设计最佳实践和案例分析

1 / 5
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功