『软件工程4』一文了解软件项目管理中的4P

软件项目管理中的4P

  • 一、项目管理的重要性和定义
    • 1、重要性(两个阶段)
    • 2、软件项目管理的定义
  • 二、管理四要素4P
    • 1、管理的四要素(4P)
    • 2、软件项目中影响最终结果的要素
    • 3、项目管理关心的问题
  • 三、项目参与者类型(people)
  • 四、项目小组结构(people)
    • 1、项目的三种一般小组组织形式
    • 2、关于小组结构的说明
    • 3、项目小组人员间的通信路径
    • 4、小组结构的选择需考虑的因素
    • 5、思考题
  • 五、软件范围及问题分解(product)
    • 1、预告
    • 2、软件范围的确定(划定问题的边界)
    • 3、问题分解(确定各部分的功能)
  • 六、过程(process)
    • 1、一般性阶段
    • 2、选择过程模型阶段
    • 3、已确定过程模型阶段
  • 七、产品和过程的二元性(product and process)
  • 八、项目的5W2H原则(project)
  • 九、写在最后——think more

在日常的软件开发中,很多人可能认为只要技术实力够了,不需要任何的软件项目管理。但殊不知的是, 软件项目管理对于整个软件项目起着至关重要的作用,甚至有可能关乎到软件项目的生死存亡。一项调查显示, 70%的项目失败是由于管理不善引起的,而并不是因为技术实力不够的原因。

那在软件项目管理当中,重要的4个因素又是什么呢?

在下面的这篇文章当中,将讲解软件项目管理中的4个重要因素4P, peopleproductprocessproject

一、项目管理的重要性和定义

1、重要性(两个阶段)

(1)20世纪70年代中期

70%的项目失败是由于管理不善引起的,而并不是因为技术实力不够;

管理是影响软件研发项目全局的因素,而技术只影响局部的因素。

(2)20世纪90年代中期

美国软件工程实施现状的调查:

10%的项目能够在预定的费用和进度下交付;

软件项目管理成为软件项目开发中最重要的核心问题之一。

2、软件项目管理的定义

(1)定义

软件项目管理是为了使软件项目能够顺利完成,而对成本人员进度质量风险等进行分析和管理的活动。

(2)对象

软件工程项目,它所涉及的范围覆盖了整个软件工程过程。

(3)何时(即什么时候做项目管理)

这种管理在技术工作开始之前就应开始,在软件从概念到实现的过程中继续进行,当软件工程过程最后结束时才终止

二、管理四要素4P

1、管理的四要素(4P)

  • 人员People —— 成功项目的重要因素;
  • 产品Product —— 要开发的软件;
  • 过程Process —— 软件工程的框架活动,包含了任务、里程碑、工作产品以及质量保证点;
  • 项目Project —— 开发软件所需要的所有工作

2、软件项目中影响最终结果的要素

  • 规模
  • 提交的期限
  • 预算和代价
  • 应用领域
  • 运用的技术
  • 系统约束
  • 用户需求
  • 可提供的资源

3、项目管理关心的问题

  • 产品的质量
  • 风险的识别和管理
  • 度量
  • 代价估算
  • 项目进度
  • 和客户交流
  • 项目成员
  • 其他资源
  • 项目监控

PS: 以下将对4P的内容进行详细分析。

三、项目参与者类型(people)

项目参与者类型一般包括以下几类:

  • 高级管理者:负责定义业务问题;
  • 项目(技术)管理者:必须计划、激励、组织和控制软件开发人员;
  • 开发人员:负责开发一个产品或应用所需的专门技术;
  • 客户:负责说明待开发软件相关需求的人以及其他风险承担者;
  • 最终用户:一旦软件发布成为产品,最终用户是直接与软件进行交互的人

总结:
①高级管理者,即定义业务问题的人;
②项目管理者,即管理软件开发的人;
③开发人员,即应用技术开发软件的人;
④客户,即提出软件需求,并承担一定风险的人;
⑤最终用户,即与软件交互的人。

四、项目小组结构(people)

1、项目的三种一般小组组织形式

(1)民主分散式(Democratic Decentralized, DD)

(2)控制分散式(Controlled Decentralized, CD)

(3)控制集中式(Controlled Centralized, CC)

2、关于小组结构的说明

(1)DD(民主分散式):没有固定的负责人,适合难度比较高、交付期限很长及生存期较长的项目,最适合于解决模块化程度比较低的问题,因为需要通信;

通俗来说:没有负责人,只有水平通信,成员之间需要广泛的两两交流。

(2)CD(控制分散式):有一个固定的负责人,若有子负责人,子负责人和总负责人的通信垂直的,而个人间的通信水平的,适合交付期限较长、比较简单的项目;

通俗来说:有固定负责人,成员之间需要交流,成员与负责人之间也需要交流;若有子负责人,成员跟子负责交流,子负责人跟总负责交流。

(3)CC(控制集中式)负责人和小组成员之间的通信垂直的,适合解决交付期限比较严格的、简单的、模块化程度高的项目

通俗来说:有固定负责人,成员之间不沟通,只跟上级沟通。

:CD和CC两种结构都需要有一个固定的负责人,而DD不用;且会比DD产生更少的缺陷。

3、项目小组人员间的通信路径

项目小组人员间的通信路径
从上图中可以看出,项目小组人数越多,通信路径越多。
通信路径计算公式为
Cn2=n(n−1)2,n表示水平通信成员间的人数C_n^2=\frac{n(n-1)}{2} ,n表示水平通信成员间的人数 Cn2=2n(n1)n

4、小组结构的选择需考虑的因素

对于一个小组来说,选择一个合适的结构需考虑以下因素:

  • 待解决软件项目的困难程度
  • 产生的程序规模,以代码行或者功能点来衡量;
  • 小组成员需要共同工作的时间(小组生存期);
  • 项目所需要的通信的程度
  • 问题能够被模块化的程度
  • 待建造系统所要求的质量和可靠性
  • 交付日期的严格程度

5、思考题

Q1:某公司有21名员工,请问分别按DD、CD、CC方式来进行组织结构的划分,各自会产生多少条的通信路径?假设在CD和CC方式下被分成四组,画出大概的组织结构图。

A1

思考题解答
下面给出无子负责人有子负责人的框架图:

无子负责人
有子负责人
写到这里,不妨再思考下,在CD和CC方式下被分成五组,有多少条通信路径?组织架构又是怎么样的呢?
评论区留下你的答案~

五、软件范围及问题分解(product)

1、预告

在开始进行一个项目之前,应该了解些什么呢?

1在进行项目计划之前,软件开发者和客户必须一起定义产品的目的和范围,考虑可选的解决方案,标识技术和管理的约束;

2)没有这些信息,就不可能进行合理的(准确的)成本估算、有效的风险评估、适当的项目任务划分或是可管理的项目进度安排

3)软件范围是软件项目管理的第一个活动。

通过下面一张图来加深对软件范围的理解。

软件范围

圆圈里的内容即软件范围,确定该项目要做什么;那么不在圈子里面的,就先抛开,也就是说,不该做的内容先不要做。

2、软件范围的确定(划定问题的边界)

1)语境;

2)信息目标;

3)功能和性能

3、问题分解(确定各部分的功能)

1)分而治之;

2)估算开始之前,范围中所描述的软件功能必须被评估和细化,以提供更多的细节。因为成本和进度的估算都是面向功能的,所以某种程度的分解通常是很有用的。

六、过程(process)

1、一般性阶段

1)软件过程的一般性阶段(定义、开发和支持)适用于所有软件项目;

2)问题在于选择一个适合项目组所要开发软件的过程模型。

回顾下上一篇文章提到过的过程模型:

  • 线性顺序模型(瀑布模型)
  • V模型
  • 原型实现模型
  • RAD模型
  • 增量模型
  • 螺旋模型
  • 形式化方法模型

2、选择过程模型阶段

项目管理者必须决定哪一个过程模型最适合用在此项目,因此在选择过程模型时需考虑以下因素:

1)需要该产品的客户和将做此工作的人员;

2)产品本身的特征;

3)软件项目组工作的项目环境。

3、已确定过程模型阶段

1)当一个过程模型被选定时,项目组基于通用过程框架活动集合,定义一个初步的计划;

2)一旦建立了初步的计划,便可以开始进行过程分解,即必须建立一个完整的计划以反映框架活动中所需要的工作任务

3)工作任务必须针对项目的特定需要进行适应性修改;且框架活动总是一样的,但工作任务则要根据一系列的适应性标准来选择。

七、产品和过程的二元性(product and process)

产品和过程的二元性
从上图中可以看出,横向坐标表示过程,纵向坐标表示产品,也就是说,每一个产品都有它对应的一系列过程。所以,在一个项目中,产品和过程都一样重要,缺了谁都不行,这也就体现了产品和过程的二元性

八、项目的5W2H原则(project)

项目的5W2H原则包含以下几点:

  • WHY —— 为什么(Why)该系统被开发?(业务目的
  • WHAT —— 将做什么(What)?(项目任务
  • WHEN —— 什么时候(When)做?(里程碑
  • WHO —— 某功能由谁(Who)负责?(角色和责任
  • WHERE —— 他们的机构组织位于何处(Where)?(角色责任界定
  • HOW —— 工作将如何(How)被技术和管理地进行?(管理和技术策略
  • HOW MUCH —— 每种资源需要多少(How much)?(资源分配

九、写在最后——think more

看完上面文章内容后,不妨试问下自己以下问题:

分析如下具体项目情况,选择合适的团队结构(CC、CD、DD)及软件过程模型,并分析原因。

Q1:在一个信息系统组织中,你被指派为项目经理。你的工作是开发一个应用程序,该程序类似于你的团队以前已经做过的某个项目,只是规模更大而且更复杂一些。需求已经由用户写成文档。

Q2:你被指派为一个小型软件产品公司的项目经理。你的工作是开发一个有突破性的产品,该产品结合了虚拟现实的硬件和高超的软件。因为家庭娱乐市场的竞争非常激烈,完成这项工作的压力很大。

Q3:你被指派为一个大型软件产品公司的项目经理。你的工作是管理该公司已被广泛使用的字处理软件的新版本的开发。因为必须获得新的收益,已经规定了紧迫的最后期限并对外公布。

Q4:在一个为遗传工程领域服务的公司中,你被指派为项目经理。你的工作是管理一个软件新产品的开发,该产品能够加速基因分解的速度。这项工作是面向研究及开发的,但其目标是在下一年度内生产出产品。

评论区留下你的答案٩(๑❛ᴗ❛๑)۶

PS 本文篇幅较长,有不理解或者有误的地方欢迎私聊或加我微信 MondayLaboratory 交流~

  • 公众号:星期一研究室
  • 微信:MondayLaboratory

如果这篇文章对你有帮助,记得留下star哦~

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

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

相关文章

8-1 回溯法实验报告 (15 分)(思路+详解)

一:题目 给定k个正整数,用算术运算符,-,,/ 将这k个正整数连接起来,是最终的得数恰为m。 如果有多组满足要求的表达式,只要输出一组,每一步算式用分号隔开。 如果无法得到m&#xff…

TypeScript 4.0 发布

喜欢就关注我们吧!整体看来,此版本在兼容性方面没有特别大的变化。因为 TypeScript 团队表示新版本继续使用与过去版本相似的版本控制模型,可将 4.0 视作 3.9 的延续升级版本。而且他们也一直在追求不牺牲主要灵活性的情况下,提供…

『软件工程5』详解软件项目管理之软件的度量

软件项目管理——软件的度量一、度量的目的1、引例2、度量的目的3、度量的作用二、测量、度量和指标区别1、引例2、测量、度量和指标的区别3、思考题三、过程度量和项目度量1、过程2、项目四、度量的方式1、物理世界中的测量2、软件测量五、面向规模的度量1、定义2、有用度量的…

7-2 旅行售货员 (10 分)(TSP问题思路加详解)

一题目 某售货员要到若干城市去推销商品,已知各城市之间的路程(或旅费)。他要选定一条从驻地出发,经过每个城市一遍,最后回到驻地的路线,使总的路程(或总旅费)最小。 输入格式: 第一行为城市数n 下面n行…

从零开始内建你的安全测试流程

一、 安全测试的意义安全问题,没发生的时候我们可以侥幸,一旦发生生产安全问题,对很多公司来说可能就是黑天鹅事件了。平台的安全,是我们测试中不可舍弃的一环,而且需要长期持续的关注。二、 从哪里入手很多公司没有专…

『软件测试1』你需要了解的软件测试基础知识

软件测试基础一、 软件缺陷的概述1、什么是软件缺陷2、软件缺陷的类型3、软件缺陷的案例4、软件缺陷的产生原因5、软件缺陷的分类6、软件缺陷的处理流程7、多学一招:缺陷报告(由测试人员完成)8、常见软件缺陷管理工具9、修复软件缺陷的成本二…

直连路由和静态路由(实验)

一:概念 1:直连路由概念 根据 路由 器学习路由信息、生成并维护 路由表 的方法包括直连路由(Direct)、 静态路由 (Static)和 动态路由 (Dynamic)。直连路由:路由器接口所连接的子网的路由方式称为直连路由; 非直连路由:通过路由协议从别的路…

使用 GB28181.Solution + ZLMediaKit + MediaServerUI 进行摄像头推流和播放

使用 GB28181.Solution ZLMediaKit MediaServerUI 进行摄像头推流和播放独立观察员 2020 年 8 月 25 日一、摄像机 GB28181 配置打开 国标 28181 配置页面,勾上 “接入使能”:打钩的是重要的配置信息,主要就是 SIP 服务器的信息和摄像头自己…

将 .NET Framework 项目转换为 .NET Standard 项目

将 .NET Framework 项目转换为 .NET Standard 项目独立观察员 2020 年 8 月 20 日如今 .NET Core 是未来发展的主流(至少在 .NET 5 发布之前),而我们如果要改造一个项目为 .NET Core 项目,则它引用的项目应当先改造为 .NET Standa…

7-3 最短路径 (20 分)(分支限界+思路+详解)

一:题目 给定一个有N个顶点和E条边的无向图,顶点从0到N−1编号。请判断给定的两个顶点之间是否有路径存在。如果存在,给出最短路径长度。 这里定义顶点到自身的最短路径长度为0。 进行搜索时,假设我们总是从编号最小的顶点出发&a…

一份【软件工程】的学习指南已到达,请注意查收!!

软件工程——起始篇一、引言二、学习【软件工程】的原因1、软件设计师证书2、相关领域人员必备技能三、【软件工程】的学习方法1、不要盲目为了学习而学习2、规划学习路线四、结束语【软件工程】应该是大学计算机专业必修的一门课,对于开发者来说,可能有…

『软件工程6』详解软件项目管理之软件范围与估算

软件项目管理——软件范围与估算一、软件项目计划1、目标2、步骤二、软件范围1、软件范围定义2、软件范围——引例三、影响估算的因素四、软件项目资源1、软件项目资源构成2、分析图3、人力资源4、硬件资源5、软件工具6、可复用构件五、软件工作量与成本的估算1、基于LOC估算工…

【翻译】.NET 5 Preview8发布

今天,.NET 5预览8发布了,对于.NET5.0的功能开发已经完成了,这必须要排除待处理的bug,预览8是最后一次预览版本。预计11月正式的.NET5.0版本发布之前还将发布两个正式之前的候选版本,这篇文章描述了.NET5.0版本中的一系…

7-1 页面置换算法--FIFO (50 分)(思路详解)

一:题目 先初始化页面大小,和物理块数。连续输入页面的逻辑地址,以“-1”作为结束标志,采用FIFO页面置换算法、固定分配局部置换分配策略。输出该页面的页号和页内位移,若该页不在内存,并且还有剩余的物理块&#xff…

7-2 页面置换算法--LRU (50 分)

一:题目(思路详解运行时错误解决) 先初始化页面大小,和物理块数。连续输入页面的逻辑地址,以“-1”作为结束标志,采用LRU页面置换算法、固定分配局部置换分配策略。输出该页面的页号和页内位移,若该页不在内存,并且还…

『软件测试3』八大典型的黑盒测试方法已来袭,快快接住!

文章目录一、等价类划分法1、定义2、等价类划分法步骤3、设计测试用例步骤4、案例:学生选修课程二、边界值分析法1、边界值分析法概述2、设计测试用例3、边界值设计原则三、错误推测法1、错误推测法概述2、错误推测法基本思想四、因果图设计法1、因果图设计法概述2、…

使用Jenkins来发布和代理.NetCore项目

Back toStudy!注:书接上文,上回《【CI/CD系列】使用Docker安装Jenkins》咱们说到了使用Docker镜像的方式,来建立Jenkins服务,用来持续集成和持续发布项目,但是上一篇文章有两个问题:01创建的容器不能操作和…

数据库课设(足球联赛管理系统)

一:前言 如果有关注博主的粉丝,可能会发现贴心杰又缺更好几天了,但是我是宠粉杰啊,怎么可能会忘了我的宝贝粉丝呢,只不过是临近期末,各种大作业课设如期而至,这几天我在写数据库课设&#xff0…

.NET Core实用技巧(一)如何将EF Core生成的SQL语句显示在控制台中

前言笔者最近在开发和维护一个.NET Core 项目,其中使用几个非常有意思的.NET Core 相关的扩展,在此总结整理一下。EF Core 性能调优如果你的项目中使用了 EF Core, 且正在处于性能调优阶段,那么了解 EF Core 生成的 SQL 语句是非常关键的。那…

695.岛屿的最大面积(026)BFS

二:思路 1.这里的遍历数据方式为BFS广度遍历 2.当我们遇到一个‘1’的时候,我们就遍历他的左右上下(邻接点),如果是1那就入队,直到队列 为空为止。 3.我们记录每个岛屿的面积是采用 我们设置初始值为1,当每遇到一个邻…