系统架构设计师-软件工程(1)

这篇具有很好参考价值的文章主要介绍了系统架构设计师-软件工程(1)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一、软件过程模型      

        1、瀑布模型

        2、V模型【瀑布变种】

        3、原型模型

        4、螺旋模型【原型+瀑布】

        5、构件组装模型/基于构件的开发方法

        6、快速应用开发RAD【瀑布+构件组装】                

        7、统一过程/统一开发方法(RUP)

        8、敏捷开发方法

二、逆向工程       

三、净室软件工程


一、软件过程模型      

        (1)瀑布模型、(2)V模型【瀑布变种】、(3)原型模型

        (4)螺旋模型【原型+瀑布】、(5)构件组装模型/基于构件的开发方法、

        (6)快速应用开发RAD【瀑布+构件组装】、(7)统一过程/统一开发方法

        (8)敏捷开发方法

        1、瀑布模型

                系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程

                【特点】:

                        (1)严格区分阶段,每个阶段因果关系紧密相连

                        (2)只适合需求明确的项目

                【缺点】:

                        (1)软件需求完整性、正确性难确定

                        (2)严格串行化,很长时间才能看到结果

                        (3)瀑布模型要求每个阶段一次性完全解决该阶段工作,这不现实

        2、V模型【瀑布变种】

                瀑布的改进,测试贯穿于始终,测试分阶段,测试计划提前。

                系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程

        3、原型模型

系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程

                设计一个简易系统,了解用户的需求,客户可以看到他们想要改变的,有利于提高用户界面的接受程度,适合需求不明确的项目,原型主要用在需求阶段。

                原型模型两个阶段:

                (1)原型开发阶段:通过做一个简易原型,向客户了解具体需求。
                (2)目标软件开发阶段:通过获取到的具体需求,完成目标软件的开发。

                原型相关模型:

                系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程

                (1)螺旋模型

                (2)抛弃型原型(也叫快速原型模型):用户需求确定之后即不再继续开发此原型。

                (3)演化型原型:逐步改进和细化原型,将原型进化为最终系统。

                (4)增量模型:在建立软件总体设计基础上,采用增量开发方法,使原型成为最终系统。

                        迭代与增量模型区别:

                系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程 

                                 

        4、螺旋模型【原型+瀑布】

                兼顾了快速原型迭代的特征以及瀑布模型的系统化与严格监控。螺旋模型最大的特点在于引入了其他模型不具备的风险分析,使软件在无法排除重大风险时有机会停止,以减小损失。同时,在每个迭代阶段构建原型是螺旋模型用以减小风险的途径。螺旋模型更适合大型的昂贵的系统级的软件应用。

                系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程

                

(1)制定计划:确定目标,选定实施方案,弄清项目开发的限制条件;

(2)风险分析:分析评估所选方案,考虑如何识别和消除风险;

(3)实施工程:实施软件开发和验证;

(4)客户评估:评价开发工作,提出修正建议,制定下一步计划。

        5、构件组装模型/基于构件的开发方法

                【优点】易扩展、易重用、降低成本、安排任务更灵活。

                【缺点】构件设计要求经验丰富的架构师、设计不好的构件难重用、强调重用可能牺牲其他指标(如性能)、第三方构件质量难控制。

                【示例】方舱医院、乐高积木

                构件 --> 服务 --> 微服务(一种标准化程度很高的构件)

                系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程

                基于构件的软件工程(CBSE):

                        CBSE体现了【购买而不是重新构造】的哲学。

                        【CBSE构件应该具备的特征】:

                        (1)可组装性:所有外部交互必须通过公开定义的接口进行。

                        (2)可部署性:构件总是二进制形式的,能作为一个独立实体在平台上运行

                        (3)文档化:用户根据文档来判断构件是否满足要求。

                        (4)独立性:可以在无其他特殊构件的情况下进行组装和部署。

                        (5)标准化:符合某种标准化的构件模型

                        【构件的组装】:

                        (1)顺序组装:按顺序调用已经存在的构件,可以用两个已经存在的构件来创造一个新的构件。

                        (2)层次组装:被调用构件的 ”提供“ 接口必须和调用构件的 ”请求“ 接口兼容

                        (3)叠加组装:多个构件合并成新构件,新构件整合原构件的功能,对外提供新的接口

        6、快速应用开发RAD【瀑布+构件组装】                

系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程

     

        7、统一过程/统一开发方法(RUP)

                系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程

                初始:(1)定义最终产品视图和业务模型(2)确定系统范围

                细化:(1)设计及确定系统架构(2)制定工作计划及资源要求

                构造:(1)开发剩余构件和应用程序功能,把这些构件集成为产品,并进行详细测试

                移交:(1)确保软件对最终用户是可用的,进行β3测试,制作产品发布版本

 系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程

        8、敏捷开发方法

                1、极限编程(XP):价值观【交流、朴素、反馈、勇气】、近螺旋式的开发方法。

                2、水晶方法提倡 “机动性” 的方法,拥有对不用类型项目非常有效的敏捷过程。

                3、迭代式增量软件开发过程(SCRUM):侧重于项目管理。

                4、特征驱动开发方法(FDD):认为有效的软件开发需要3要素【人、过程、技术】。定义了6种关键的项目角色:项目经理、首席架构师、开发经理、主程序员、程序员和领域专家

                5、开放式源码:程序开发人员在地域上分布很广【其他方法强调集中办公】。

                6、自适应软件开发(ASD):其核心是三个非线性的、重叠的开发阶段:猜测、合作与学习。

                7、动态系统开发方法(DSDM):倡导以业务为核心。

                敏捷宣言:

                        (1)个体和交互胜过过程和工具(2)可工作的软件胜过大量的文档

                        (3)客户合作胜过合同谈判(4)响应变化胜过遵循计划

系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程

                敏捷方法 - XP (极限编程):

                        4大价值观:

                                (1)沟通【加强面对面沟通】(2)简单【不过度设计】

                                (3)反馈【及时反馈】(4)勇气【接受变更的勇气】

                        12条过程实践规则:

                                (1)简单设计(2)测试驱动(3)代码重构(4)结对编程

                                (5)持续集成(6)现场客户(7)发行版本小型化(8)系统隐喻

                                (9)代码集体所有制(10)规划策略(11)规划代码(12)40小时工作制

                敏捷方法 - SCRUM(迭代式增量软件开发过程):

系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程

                Scrum的工作流程包括以下几个步骤:            
                        1、产品负责人确定产品需求和优先级,将它们整理成一个产品待办列表。
                        2、Scrum Master和开发团队一起参加迭代计划会议,确定下一个迭代的目标和计划。
                        3、在迭代周期内,开发团队每日进行短暂的站立会议,交流进展和遇到的问题。
                        4、在迭代开发结束时,开发团队进行回顾会议,评估完成的工作和改进方法。
                        5、根据产品待办列表,确定下一个迭代的目标和计划,开始新的迭代周期。

                Scrum的优势,
                        1、更快的交付:通过迭代和增量的方法,团队可以更快地交付高质量的成果。
                        2、更好的合作:Scrum鼓励团队成员之间的互动和交流,促进了更好的合作和协作。
                        3、更好的控制:Scrum的固定时间和可视化进度可以帮助团队更好地控制项目进度。
                        4、更好的风险管理:Scrum的迭代式方法可以帮助团队更好地管理风险和问题。 

二、逆向工程       

系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程

         与逆向工程相关的概念有重构、设计恢复、再工程和正向工程。

        (1)重构/重组(Restructuring):重构是指在【同一抽象级别】上【转换系统描述形式】。是对源代码、数据进行修改,使其易于修改和维护,以适应将来的变更。

        (2)设计恢复(Design Recovery):设计恢复是指借助工具从已有程序中抽象出有关数据设计、总体结构设计和过程设计等方面信息。

        (3)逆向工程(Reverse Engineering):逆向工程是分析程序,力图在比源代码更高抽象层次上建立程序的表示过程,逆向工程是设计的恢复过程

        (4)正向工程(Forward Engineering):正向工程是指不仅从现有系统中恢复设计信息,而且使用该信息去改变或重构现有系统,以改善其整体质量

        (5)再工程/重构工程(Re-engineering):再工程是对现有系统的重新开发过程,包括逆向工程、新需求的考虑过程和正向工程三个步骤。

三、净室软件工程

        属于形式化方法,数学理论为基础,以验证为导向,而不是测试。

系统架构设计师-软件工程(1),系统架构师,软考高级,系统架构,软件工程

        1、净室即无尘室、洁净室。也就是一个受控污染级别的环境

        2、使用盒结构规约(或形式化方法)进行分析和设计建模,并且强调将正确性验证,而不是测试,作为发现和消除错误的主要机制。

        3、使用统计的测试来获取认证被交付的软件的可开行所必需的出错率信息。

      【技术手段】

                1、统计过程控制下的增量开发控制迭代

                2、基于函数的规范和设计盒子结构

                        定义三种抽象层次:行为视图(黑盒)-> 有限状态机视图(状态盒) -> 过程视图(明盒

                3、正确性验证:净室工程核心。

                4、统计测试和软件认证:使用统计学原理,总体太大时必须采用抽样方法

         【缺点】

                1、太理论化,正确性验证的步骤比较困难且耗时

                2、开发小组不进行传统的模块测试,这是不现实的

                3、脱胎于传统软件工程。不可避免带有传统软件工程的一些弊端文章来源地址https://www.toymoban.com/news/detail-516499.html

到了这里,关于系统架构设计师-软件工程(1)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 软件设计师——软件工程(四)

    本文主要是【软件工程】——软件设计师——软件工程的文章,如果有什么需要改进的地方还请大佬指出⛺️ 🎬作者简介:大家好,我是听风与他🥇 ☁️博客首页:CSDN主页听风与他 🌄每日一句:狠狠沉淀,顶峰相见 21.某开发小组欲为一公司开发一个产品控制软件,监控

    2024年01月24日
    浏览(42)
  • 中级软件设计师备考---软件工程1

    瀑布模型 :最早的一类、适用于需求明确的项目、 结构化 的典型代表 原型模型:先构造一个建议的系统原型再去和用户深入多次交流,不断地根据用户需求进行调整 演化模型:一步步变化,最后得到产品 增量模型:先完成项目的核心功能,然后一步步增加功能 螺旋模型

    2024年02月02日
    浏览(49)
  • 软件设计师(五)软件工程基础知识

    软件开发和维护过程中所遇到的各种问题称为“软件危机”。 软件工程是指应用计算机科学、数学及管理科学等原理,以工程化的原则和方法来解决软件问题的工程,其目的是提高软件生产率、提高软件质量、降低软件成本。 计算机软件是指计算机系统中的程序及其文档。

    2024年02月14日
    浏览(43)
  • 【中级软件设计师】—(针对上午题)软件工程上(三十五)

    环的个数=闭合区域+ 1,上图环的个数为:2+1=3 注意:每个边都应该有两个结点相对应,不懂看B站软件工程上视频 P95集 需要2个测试用例 答案:B D 答案:A C 系统可维护性的评价指标:理解、测试、修改 D 选项:在软件工程的每一个阶段都应考虑并提高软件的可维护性 B选项:

    2024年02月04日
    浏览(40)
  • ③ 软件工程CMM、CMMI模型【软考中级-软件设计师 考点】

    个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~ 个人主页:.29.的博客 学习社区:进去逛一逛~ CMM : CMM将软件过程改进分为以下5个熟练度: 初始级 软件过程的特点是 杂乱无章 ,有时甚至很 混乱 ,几乎

    2024年02月06日
    浏览(38)
  • 推荐10款设计师都在用的3d机械工程软件

    新产品和系统的研究和开发需要特定的软件。您必须能够设计建筑物、系统、机械和设备的蓝图和示意图。您还需要能够与其他工程师、绘图员和团队成员协作,同时有效且高效地工作。设计工程师的软件必须简化其流程,以避免妨碍他们的设计和开发工作。 好的工程设计选

    2024年02月16日
    浏览(41)
  • 系统架构设计师-软件架构设计(3)

    目录 一、软件架构风格(其它分类)         1、闭环控制结构(过程控制)           2、C2风格         3、MDA(模型驱动架构 Model Driven Architecture)         4、特定领域软件架构(DSSA)                 4.1 DSSA基本活动及产出物:             

    2024年02月15日
    浏览(47)
  • 系统架构设计师-软件架构设计(7)

    目录 大型网站系统架构演化 一、第一阶段:单体架构 到 第二阶段:垂直架构 二、第三阶段:使用缓存改善网站性能         1、缓存与数据库的数据一致性问题         2、缓存技术对比【MemCache与Redis】         3、Redis分布式存储方案         4、Redis集群切片的

    2024年02月14日
    浏览(56)
  • 系统架构设计师-软件架构设计(6)

    目录 一、物联网分层架构 二、大数据分层架构 三、基于服务的架构(SOA)         1、SOA的特征         2、服务构件与传统构件的区别 四、Web Service(WEB服务)         1、Web Services 和 SOA的关系 五、REST(表述性状态转移) 六、ESB(企业服务总线) 七、微服务         1、微

    2024年02月14日
    浏览(76)
  • 【新版】系统架构设计师 - 软件架构设计<新版>

    个人总结,仅供参考,欢迎加好友一起讨论 软件架构的概念(★★★) 基于架构的软件开发(★★★★) 软件架构风格(★★★★★) 特定领域软件架构(★★★) 软件质量属性(★★★★★) 软件架构评估(★★★★★) 软件产品线(★★★) 构件与中间件技术(★

    2024年02月09日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包