【信管2.3】项目生命周期

news2025/1/17 15:25:35

项目生命周期

上一篇文章内容有点多呀,消化完了吗?其实吧,最主要的就是那三种组织形式而已,别的真没什么,记住它们的优缺点和项目经理的权力大小就可以了。今天我们轻松点,虽说还是挺重要的,但要记住它们并不是在今天。我们要了解一下项目的生命周期,以及在 IT 项目开发中常用的典型生命周期。其实这些内容我们在技术相关的内容中都已经有涉及过,这里只是更详细的再说明一下。看到下面的内容你一定不会感到非常陌生的。最后,我们还要提一下项目管理过程,也就是大家翘首以盼的 PMBOK 十大过程领域,当然,只是简单的介绍下,因为每个过程域我们在后面都会详细地学习。

项目生命周期

在技术相关的第一课,也就是 【信管1.1】信息系统与信息化https://mp.weixin.qq.com/s/-zYr7LO9OaeZfIEfziflpg 中,我们就提到过信息系统生命周期的概念。其实它本质上就是从项目生命周期演化产生的。项目生命周期指的是项目从启动到收尾所经历的一系列阶段。阶段通常都有时间限制,有开始点、结束点或控制点。

从预测型(或计划驱动的)方法到适应型(或变更驱动的)方法,项目生命周期可以处于这个连续区间内的任何位置。在预测型生命周期中,在项目开始时就对产品和可交付成果进行定义,对任何范围变化都要进行仔细管理。而在适应型生命周期中,产品开发需要经过多次迭代,在每次迭代开始时才能定义该次迭代的详细范围。

b85e4db68929f5c6d85037c0559c945f.jpeg

上面这个项目的生命周期图中,我们可以看到 启动项目、组织与准备、执行项目工作 以及 结束项目 这四个阶段,其实换个单词就是 启动、计划、执行、收尾 这个四个步骤。如果再加上一个全程的 监控 的话,就演变成了完整的 PMBOK 的五大项目过程组。

不同的阶段其实并没有特别严格的划分方法,阶段通常是以一个或多个可交付成果的完成为结束的,通常这些阶段也需要遵循一些规定:

  • 每个阶段要完成哪些技术工作

  • 每个阶段的交付物何时及如何产生

  • 每个阶段都有哪些人员参与

  • 如何控制和批准每个阶段

在上面的图中,我们还看到了一条曲线,这条曲线代表的是成本与人力投入的水平。我们可以看到,成本与人力投入在开始时较低,在工作执行期间达到最高,并在项目快要结束时迅速回落。不过,成本和人力投入的这条曲线并不是适用于所有项目的,因为有的项目可能在生命周期早期支出较大,以确保所有的资源到位,也就是说,给予的资源投入从一开始就是顶峰。

除了成本和人力外,项目的风险不确定性和变更代价也会随着项目的进展而产生变化。

bad88f4e3f7e1b0c4c299a162b99e436.jpeg

从图中我们可以看到两条曲线。其中风险与不确定性在项目开始时最大,并在项目的整个生命周期中随着决策的制定与可交付成果的验收而逐步降低。另一条变更的代价则是反过来的,在不显著影响成本的前提下,改变项目产品最终特性的能力在项目开始时最大,并随项目进展而减弱。其实就是说,在项目开始阶段,变更不需要付出太多的代价,而越接近项目结束,所要付出的代价也就越来越大。

项目生命周期通常是产品生命周期的一部分,并且是被包含于产品生命周期的。这个我们在最早的那一课中也看到过。

信息系统的项目典型生命周期模型

项目生命周期还是比较好理解的吧,毕竟这是我们第二次学习了。接下来的内容其实也是我们之前讲过的,而且是紧接着第一课的内容,也就是 【信管1.2】信息系统开发方法https://mp.weixin.qq.com/s/HLD1haIjUs9g8CC9-El2Ag 中提到的内容。我们在学习与之对应的信息系统开发方法时会同步回顾之前的内容。以下内容非常经典,是所有软件工程教材中必有的内容,重点哦!

瀑布模型

最最经典的,不提他就没法说软件工程和软件项目管理。重要到什么程度呢?后面所有要讲的东西,只是翻来覆去对它的变形优化,本质上没有特别的不同。

23aafa1917d24ed0084a7d75469f7055.jpeg

估计不少同学可能现在在公司就是这样的开发模式吧。我们从可行性分析(计划)开始,依次经历需求分析、软件设计(概要设计、详细设计)、编码(含单元测试)、测试、运行维护等几个阶段,一步步地走下来。它对应的就是我们之前学习过的 结构化方法 。

也就是说它的特点和优劣势和 结构化方法 是一样的,只不过 结构化方法 更偏方法论。而瀑布模型我们可以用更具体的项目化的术语总结一下:

  • 优点:具有检查点;关注后续阶段;在迭代中可以使用;模板化的开发可以实现共同指导。

  • 缺点:阶段划分相对固定,严格区分阶段,并且包含大量的文档;线性化的开发,到末期才能看到结果;不适应变化。

你可以再回顾一下我们在学习结构化方法时总结的优缺点,不管是简答还是选择题,这两个概念有很多内容都是相通的,也是可以互相拿分的。

V模型

如果你的项目很注重质量,也就是交付的成果对质量的要求非常高,那么 V模型 就是不可或缺的神器。

08deafb88998ff454543fe99715c2807.jpeg

熟悉吗?惊讶吗?这不就是在 瀑布模型 的基础上为对应的阶段增加了对应的测试嘛。它的重要意义在于,非常明确地表明了测试过程中也是一样存在不同的级别的,并且可以对应到我们 瀑布模型 的开发流程中。V模型体现的主要思想就是开发和测试是同等重要的。相信右边的这些测试是什么意思不用多解释了吧。如果有不记得的小伙伴可以回去再复习一下哦。【信管1.10】软件工程(四)软件测试与质量保证https://mp.weixin.qq.com/s/qxhpONT2d9HBRhEN3AbZBQ。

对了,我们在之前的课程中没有提到过验收测试,其实验收测试就是最后在正式的线上环境中的演示,演示对象就是我们的客户或者用户。

螺旋模型

刚刚说了如果看重质量,那么你应该选择 V模型 ,而如果项目很注重风险,有很大的风险隐患,那么你的最佳选择就应该是螺旋模型了。

12b341472bf7232e3f317090f506279c.jpeg


这一圈一圈的看不懂吧?我第一次看的时候也是一脸懵的。其实,你可以从左上角的 制订计划 看起,然后顺时针依次看到 风险分析、 实施工程 和 客户评估 。然后不停的这样顺时针旋转进行项目的开发。是的,我估计你猜到了,计划、执行、收尾,中间加了一个 风险分析 。

螺旋模型是一种深化软件的过程模型,将迭代增量的方式与线性顺序(瀑布)中控制的和系统化的方面结合起来,使得软件增量版本的快速开发成为可能。更重要的是,它在其中增加的 风险分析 ,当发现项目产品有问题的时候,我们可以马上终止开发。

综上所述,螺旋模型特别适用于复杂的、高风险、不成熟的项目。

迭代模型

迭代这个词其实是在敏捷开发中发扬光大的,在之前的敏捷学习中,我们知道迭代就是在一个固定的时间内去交付某些有价值的成果。真正的迭代模型其实是早于敏捷的,是敏捷采用了这一模型。

一次迭代就可以看成是一次小瀑布,整个迭代开发过程就是不断重复的小瀑布循环。

d94c5f3903b36eeff38b5451b4c0c789.jpeg

从这个表中,我们看出迭代模式也是包含不同阶段的,初始、细化、构造、移交 这四个阶段中的小瀑布又有着不同的工作量占比。比如说,在初始阶段,需求工作就是非常重要的部分,而在构造阶段实现就占了非常大的比重。

我们教材上的这个迭代模型的图示,在网上被广泛用于另一个经典模式的解释 统一过程RUP 。

统一过程(RUP/UP,Rational Unified Process)是一种以用例驱动、以体系结构为核心、迭代及增量的软件过程模型,由UML方法和工具支持,广泛应用于各类面向对象项目。它本身也是迭代模型的一种,可以归类为迭代模型之下。

除此之外,螺旋模型,很明显的也可以看出是迭代模型一类的模型。还有一种面向对象的迭代模型,称为 喷泉模型 。

fc26a21d85464ef2e70452aa08b059d9.jpeg

原型化模型

原型化模型的第一步就是创建一个快捷原型,能够满足项目干系人与未来的用户可以与原型交互,再通过与相关干系人进行充分的讨论和分析,最终弄清楚当前系统的需求,进行了充分的了解之后,在原型的基础上开发出用户满意的产品。

在螺旋模式中,我们就提到过原型化开发,其实它就是为了弥补瀑布的变更代价高昂的缺点。在开发前,我们用最小的代价来产出一个原型用于确认需求。

原型可以不用写代码,线框图、低保真、高保真原型几乎已经成为了 产品经理 的代表工具。使用 Axure 的高手做出来的动态高保真原型是真的能够达到以假乱真的地步的。

因此,原型模式其实现在已经被 产品经理 广泛使用了。而我们技术可以快速实现的类似原型的一种开发形式为 MVP ,也就是敏捷中的 最小可行性产品。大家可以在之前的敏捷课程中回顾一下。

原型根据使用的结果可以分为两类:

  • 抛弃型原型:此类原型在系统真正实现以后就放弃不用了。

  • 进化型原型:此类原型的构造从目标系统的一个或几个基本需求出发,通过修改和追加功能的过程逐渐丰富,演化成最终系统。

敏捷开发模型

敏捷开发,额,之前已经写过太多了,有兴趣的小伙伴去看看吧!

好吧,说下重点,了解一下敏捷开发在这边的重点关注的内容就好了。它适合小团队、小规模的项目,小步快跑模式。其实实现的就是 增量迭代 的方式来进行开发。

剩下的希望大家还是去看下我之前的 PMI-ACP 相关课程吧。

逆向工程

逆向工程,从技术的角度来说就是通过反编译等手段,将一个软件进行解构分析。比如说在十多年前,反编译 Android 应用来参考别人的代码实现是非常常见的情况。

逆向工程包括 设计模型(实现级)的逆向,也就是完全恢复之前的系统;程序数据结构信息(结构级)恢复数据及算法;对象模型、数据和控制流模型(功能级)恢复设计内容文档 以及 UML状态图和部署图(领域级)恢复设计流。

逆向工程这一块,了解一下就好啦。

项目过程组与知识域

项目管理从实现上来说,其实就是将知识、技能、工具和技术应用于项目活动之中,以满足项目的要求。它是通过利用项目管理知识、技能、工具和技术的过程实现的,这些过程凭借每个过程的输入条件创造出成果。也就是说,每个过程都会有自己的 输入、输出 以及相应的 工具、技术、方法 。

81fde4674394c650a0dc2443c8eacd8b.jpeg

过程就是一组为了完成一系列事先指定的产品、成果或服务而需执行的互相联系的行动和活动。在项目管理过程中,我们其实最主要关心的就是项目生命周期的那五大过程:启动、计划、执行、控制 和 收尾。之前也已经说过了,这五方面的内容构成了 PMBOK 理论体系中的 五大过程组 。

  • 启动过程组:定义并批准项目或项目阶段。

  • 计划过程组:定义和细化目标,并为实现项目需要达到的目标和完成项目要解决的问题范围而规划必要的行动路线。

  • 执行过程组:整合人员和其他资源,在项目的生命期或某个阶段执行项目管理计划。

  • 监督与控制过程组:定期测量和监控项目绩效情况,识别与项目管理计划的偏差,以便在必要时采取纠正措施,确保项目或阶段目标达成。

  • 收尾过程组:正式验收产品、服务或工作成果,有序的结束项目或项目阶段。

在这五个过程组中分别穿插着 PMBOK 知识体系中的十大知识域。知识域中的每个过程的成果一般会成为另一个过程的依据或成为项目的可交付的成果。如果是依据的话,那么也就是另一个过程的输入。它们之间相互影响、相互作用。

14850d49563d1823aa1c3dbae9387ccc.jpeg

上面这张图相信学过 PMP 的同学简直是再熟悉不过了。在 信管师 的考试中,和 PMP 是一样的要求,这张图中的表格,表格中的内容,必须全部背下来。没有为什么,考试考的就是它!!信管师考试下午的简答、论文都和它有关。当然,现在就要你背下来还是有点强人所难的,因为你还不知道这一堆东西是干嘛的,因此,在我们讲完所有的课程之后,请你回过头来,把它背下来。这张表格的重要程度 10000% 。

如果你希望有 Excel 表格形式或者更清晰的版本,可以去搜索 PMBOK 第五版的电子书,因为我们 信管师 教程中项目管理知识体系是以 PMBOK 第五版为基础的。当然,你也可以使用我的小程序 PMP知识域 来进行背诵。在这个小程序中,我们主要是背诵 PMP 的 ITTO (Input、Output、Tools and Technology) ,也就是每个过程的 输入、输出、工具和技术 这三部分内容。信管师对这个要求还好,但我建议你最好也能背下来。

pmp知识域

表格中的十大知识领域,用一句顺口溜来说的话,可以记成:范围时间成本质量是核心,人力沟通风险采购干系人是辅助,整体管理来归一。

e76b887b9589f5fe4cb43817a3d47680.jpeg

项目的整个开发过程其实就是上图所展示的,注意中间那个环。其实它就是根据大名鼎鼎的 戴明环 演变而来,也就是我们在敏捷中说过的 PDCA 循环。这四个字母分别代表的是 Plan、Do、Check、Act 。虽说它叫做 戴明环 但其实它是由 瓦特 提出,戴明 进行完善的。更多具体的内容大家可以自行查阅相关的资料文档,或者去之前我们敏捷的课程中找找哦。

总结

今天的重点内容是什么呢?不用我说大家也能看出来,项目过程管理组和知识域的那张大表格,不过幸好,今天你还不需要去把它背下来,但它,是我们整个课程的超级重点。等你学完全部的项目管理知识后,再背它也会变得很容易。另外项目生命周期中的重点是信息系统项目典型生命周期这部分的内容,也不需要完全的记忆,我们只要看到名字就能知道这些模型的特点就可以了。

参考资料:

《信息系统项目管理师教程》

《某机构培训资料》

《项目管理知识体系指南 PMBOK》第六版

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/44619.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

在 Docker 容器内集成 Crontab 定时任务

本文内容Crontab 基础知识Crontab 日志问题参考链接有时候,我们需要在容器内执行某种定时任务。譬如,Kerberos 客户端从 KDC 中获取到的 TGT 默认有效期为 10 个小时,一旦这个票据失效,我们将无法使用单点登录功能。此时&#xff…

谈前端测试的重要性

如果正确完成前端测试,将使我们的用户感到满意,并在使用我们的应用程序时获得良好的性能体验。 根据 Bob 大叔的说法,测试是系统的一部分;许多开发人员认为相反,因为他们没有部署。他宣称这是一个灾难性的观点&#x…

数据可视化之平台数据分析

一 前言 近年来,随着网络技术和电子商务的发展,对科学数据分析的研究提出了更高的要求,数据分析技术随之发展起来。我们可以通过数据分析技术,发现大量金融、通信和商业数据中隐含的规律,从而为决策提供依据。这已成为…

HTML5期末考核大作业 基于HTML+CSS+JavaScript仿王者荣耀首页 游戏网站开发 游戏官网设计与实现

🎉精彩专栏推荐👇🏻👇🏻👇🏻 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 💂 作者主页: 【主页——🚀获取更多优质源码】 🎓 web前端期末大作业…

Native 内存warp

Native 启动-动态/静态&libc &linker https://www.cnblogs.com/ilocker/p/4645308.html https://www.cnblogs.com/ilocker/p/4645308.html 修改LD_PRELOAD hook java native 库函数 https://blog.csdn.net/m0_57036414/article/details/126811772 Native malloc_debug …

如何用潜类别混合效应模型(Latent Class Mixed Model ,LCMM)分析老年痴呆年龄数据

全文下载链接:http://tecdat.cn/?p24647线性混合模型假设 N 个受试者的群体是同质的,并且在群体水平上由独特的曲线 Xi(t)β 描述(点击文末“阅读原文”获取完整代码数据)。相关视频背景和定义相比之下,潜在类别混合模…

国鸿氢能冲刺港股:年亏损7亿 云浮工业园与青岛城投是股东

雷递网 雷建平 11月28日国鸿氢能科技(嘉兴)股份有限公司(简称:“国鸿氢能”)日前递交招股书,准备在港交所上市。年亏损7亿国鸿氢能成立于2015年6月,是一家以氢燃料电池为核心产品的企业&#x…

MySQL监控主从复制

show slave status; show slave status; 不够准确 使用下面的

JetpackCompose从入门到实战学习笔记3——Text的简单使用

JetpackCompose从入门到实战学习笔记3——Text的简单使用 上一篇文章我们讲解了modifier的一些简单用法,本篇就开始讲解基础控件Text的一些简单用法. 1.源码分析: Composable fun Text(text: AnnotatedString,//要显示的文本modifier: Modifier Modi…

【PAT乙级】一百一十道真题刷后大汇总——C/C++

技巧总结避免精度丢失查询数据是否存在容器之间的比较是否相等缓存区中字符残留问题巧妙输入巧妙使用hash数组简单数学质数俩数最大公约与最小公倍数因子常用的头文件及其内部函数< map >< set >< pair >< string >< vector >< algorithm >…

算法排序基础(全版)

一、简单排序 这大概是我整理的最全的有关算法排序的内容啦&#xff01;欢迎大家前来学习&#xff0c;同时也希望多多支持一下博主哦&#xff01; ​ 在我们的程序中&#xff0c;排序是非常常见的一种需求&#xff0c;提供一些数据元素&#xff0c;把这些数据元素按照一定的规则…

【C++ STL容器】:vector存放数据以及存放自定义的数据类型

前言 时不可以苟遇&#xff0c;道不可以虚行。 STL 中最常用的容器为&#xff1a;vector&#xff0c;暂且把它理解为我们之前学过的数组Array。 一、创建一个vector容器&#xff08;数组&#xff09; 添加头文件&#xff1a;#include <vector> vector<int> v;二、…

VauditDemo靶场代码审计

靶场搭建 将下载好的VAuditDemo_Debug目录复制到phpstudy的www目录下&#xff0c;然后将其文件名字修改成VAuditDemo&#xff0c;当然你也可以修改成其他的 运行phpstudy并且访问install目录下的install.php&#xff0c;这里我访问的是http://127.0.0.1/VAuditDemo/install/in…

Linux 性能分析工具- Atop安装和使用

Atop下载&#xff1a;Atoptool.nl 安装时&#xff0c;可能会出现报错&#xff1a;error: Failed dependencies 提示很需要安装python3&#xff0c;所以yum -y install python3&#xff0c;然后再装atop就没问题了。 atop 常用命令 您可在打开日志文件后&#xff0c;使用以下命…

R语言使用马尔可夫链对营销中的渠道归因建模

介绍 在这篇文章中&#xff0c;我们看看什么是渠道归因&#xff0c;以及它如何与马尔可夫链的概念联系起来。最近我们被客户要求撰写关于马尔可夫链的研究报告&#xff0c;包括一些图形和统计输出。我们还将通过一个电子商务公司的案例研究来理解这个概念如何在理论上和实践上…

QT开发教程:QScroller实现home界面滑动效果

在上章我们学习了QScroller实现home界面滑动效果,但是该界面是实现的上下滑动效果,如果想模拟手机home滑动界面,则需要实现左右滑动效果. 本章,则重写QStackedWidget类,来真正的模拟手机,来实现home界面左右滑动效果. 1.SmoothStackedWidget类实现 demo界面如下图所示(创建了…

[附源码]计算机毕业设计springboot第三方游戏零售平台

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Discourse 在 2022-11 的最新版本中提供了新的边栏

官方有关这个边栏的说明和解释文章请参考链接&#xff1a; Try out the new sidebar and notification menus! - announcements - Discourse Meta 中的内容。 在这个新设计的边栏中包含了一些所有人都需要使用的快捷链接&#xff0c;同时还包括一些定义的快捷分类链接和 Tag 链…

haproxy keepalive实践

1 安装haproxy wget http://download.openpkg.org/components/cache/haproxy/haproxy-2.6.6.tar.gz tar -zxvf haproxy-2.6.6.tar.gz cd haproxy-2.6.6 mkdir -p /app/haproxy # 安装依赖,解决haproxy.c:80:31的问题 sudo yum -y install gcc openssl-devel pcre-devel system…

【Python】一、Python程序运行方式

文章目录实验目的一、熟悉Python的安装二、熟悉PyCharm安装三、启动IDLE&#xff0c;进入Python Shell&#xff0c;熟悉环境&#xff0c;运行教材案例&#xff1a;输出“hello world&#xff01;”四、打开“命令提示符”窗口&#xff0c;使用pip安装管理pygame、numpy等第三方…