resources:"Software Engineering" Ian Sommerville


For most projects, important goals are:

  • Deliver the software to customer at the agreed time.
  • Keep overall costs within budget.
  • Deliver software that meets the customer's expections.
  • Maintain a happy and well-functioning development team.

Keywords:

  • organizational budget
  • schedule constraints
  • project meets
  • high-quality

The reponsibilities of managers:

  • Project planning
  • Reporting
  • Risk management
  • People management
  • Proposal writing: The first stage in a software project may involve writing a proposal to win a contract to carry out an item of work. The proposal describes the objectives of the project and how it will be carried out. It usually includes costs and schedule estimates and justifies why the project contract should be awarded to a particular organization or team.

1. Risk management

Three related categories of risk:

  • Project risks: risks that affect the project schedule or resources

    • example: the loss of experienced designer
  • Product risks: risks that affect the quality or performance of the software being developed
    • example: the failure of a purchased component to perform as expected
  • Business risks: risks that affect the organization developing or procuring the software
    • example: a competitor introducing a new product is a business

You may need to draw up contingency plans so that, if the risks do occur, you can take immediate recovery action.

Examples of common risks:

  • Staff turnover :Experienced staff will leave the project before it is finished
  • Management change
  • Hardware unavailability
  • Requirements change
  • Specification delays
  • Size underestimate
  • CASE tool underperformance
  • Technology change
  • Product competition

The process of risk management:

  1. Risk identification
  2. Risk analysis
  3. Risk planning
  4. Risk monitoring

1.1 Risk identification

Risk identification may be a team process where a team get together to brainstorm possible risks. Alternatively, the project manager may simply use his or her experience to identify the most probable or critical risks.

There are at least six types of risk that may be included in a risk checklist:

  1. Technology risks
  2. People risks
  3. Organizational risks: risks that derive from the organizational environment where the software is being developed.
  4. tools risks
  5. Requirements risks
  6. Estimation risks: risks that derive from the management estimates of the resources required to build the system.

1.2 Risk analysis

The probability of the risk might be assessed as very low (<10%), low (10-25%), moderate (25-50%), high (50-75%), or very high (>75%)

Once the risks have been analyzed and ranked, you should assess which of these risks are most significant.

1.3 Risk planning

There are three categoriess for strategies:

  1. avoidance strategies
  2. minimization strategies
  3. contingency plans: your are prepared for the worst and have a stratefy in place to deal with it.

1.4 Risk monitoring

Risk monitoring is the process of checking that your assumptions about the product, process, and business risks have not changed.

2. Managing people

There are four critical factors in people management:

  • Consistency: People in a project team should all be treated in a comparable way.
  • Respect
  • Inclusion: People contribute effectively when they feel that others listen to them and take account of their proposals.
  • Honesty

If some lose interest in the work, you should sort out the problem quickly, otherwise the other group members will become dissatisfied and feel that they are doing an unfair share of the work.

Motivating people

Professionals can be classified into three types:

  • Task-oriented people: motivated by the work they do
  • Self-oriented people: motiviated by personal success
  • Interaction-oriented people : motivated by the presence and actions of co-workers. As software development becomes more usercentered, interaction oriented individuals are becoing more involved in software engineering.

Interaction-oriented personalities usually like to work as part of a group, whereas task-oriented and self-oriented people usually prefer to act as individuals.

Each individual's motivation is made up of elements of each class but one type of motivation is usually dominant at any one time.

Individuals can change. For example, technical people who feel they are not being properly rewarded can become self-oriented and put personal interests before technical concerns. If a group works particularly well, self-oriented people can become more interaction-oriented.

3. Teamwork

keywords: cohesiveness

3.1 Selecting group members

A group that has complementary personalities may work better than a group that is selected solely on technical ability.

3.2 Group organization

Informal groups: most group members are experienced and competent.

Hierarchical groups [haɪə'rɑːkɪk(ə)l]: have a hierarchical structure with the group leader at the top of the hierarchy

3.3 Group communications

Group members must exchange:

  • information on the status of their work
  • the design decisions that have been made
  • changes to previous design decisions

Group members come to understand the motivations, strengths, and weaknesses of other people in the group.

The effectiveness and efficiency of communications is influenced by:

  1. Group size
  2. Group structure
  3. Group composition
  4. The physical work environment
  5. The available communication channels

Software Engineering: 2. Project management的更多相关文章

  1. SENG201 (Software Engineering I) Project

    SENG201 (Software Engineering I) ProjectSpace ExplorerFor project admin queries:For project help, hi ...

  2. Software Engineering: 3. Project planning

    recourse: "Software Engineering", Ian Sommerville Keywords for this chapter: planning sche ...

  3.  Go is more about software engineering than programming language research.

    https://talks.golang.org/2012/splash.article Go at Google: Language Design in the Service of Softwar ...

  4. Project Management Process

    Project Management ProcessDescription .............................................................. ...

  5. 10 Rules of Highly Successful Project Management

    I commited the information below to report PDU of PMI. ^_^. In this paper, the author introduces his ...

  6. 第二篇——The communication during software engineering.

    I've learned a lot in my software engineering class about how a program comes out.That's also a esse ...

  7. Software Engineering: 1. Introduction

    Resource: Ian, Sommerville, Software Engineering 1. Professional software development 1.1 Software e ...

  8. The Simplified Project Management Process

    One of the challenges of explaining project management to people who are unfamiliar with the approac ...

  9. Introduction to Project Management(II)

    Introduction The purpose of this paper is to gain an understanding of project management and to give ...

随机推荐

  1. linux常用操作指令

    Linux常用操作指令: 常用指令 ls        显示文件或目录 -l           列出文件详细信息l(list) -a          列出当前目录下所有文件及目录,包括隐藏的a(a ...

  2. kibana使用操作部分

      1.kibana的概念及特点. 概念:数据可视化平台工具 特点: - 灵活的分析和可视化平台 - 实时总结和流数据的图表 - 为不同的用户显示直观的界面 - 即时分享和嵌入的仪表板   2.kib ...

  3. 函数类型+WINAPI+函数名(例如inline DWORD static WINAPI RecordToKeys(const DRWT& theDRWT,WTSBH* pKey,DWORD dwMaxNum)

    winapi标识符在WINDEF.H定义,语句如下: #define winapi __stdcall 让我们说说这个__stdcall stdcall调用约定 stdcall很多时候被称为pasca ...

  4. Oracle 存储过程异常处理

    Oracle 存储过程异常处理 1.异常的优点    如果没有异常,在程序中,应当检查每个命令的成功还是失败,如  BEGIN  SELECT ...  -- check for ’no data f ...

  5. TCP中异常关闭链接的意义 异常关闭的情况

    终止一个连接的正常方式是发送FIN. 在发送缓冲区中 所有排队数据都已发送之后才发送FIN,正常情况下没有任何数据丢失. 但我们有时也有可能发送一个RST报文段而不是F IN来中途关闭一个连接.这称为 ...

  6. sp_executesql

    execute相信大家都用的用熟了,简写为exec,除了用来执行存储过程,一般都用来执行动态Sql  sp_executesql,sql2005中引入的新的系统存储过程,也是用来处理动态sql的, 如 ...

  7. C++ DateTime 结构

    OS:Win7 ,Tools:VS2015 DateTime.h #pragma once struct DateTime { public: unsigned Year; // years sinc ...

  8. 0511 backlog

    SCRUM 这次的作业就是确定SCRUM的计划,确定sprint backlog的一个冲刺周期,而这个周期是两个星期.争取在两周内发布1.0版本. 本次作业以网站构建为主: ID       NAME ...

  9. pb数据窗口设置操作

    1 使DataWindow列只能追加不能修改如何使DataWindow中的数据只能追加新记录而不能修改,利用 Column 的 Protect 属性可以很方便的做到这一点,方法如下:将每一列的 Pro ...

  10. 使用uiautomator做UI测试

    转载~~~~~~~~~~~~~~~~~~~~~~~~ 若有侵权,请及时联系本博主,博主将第一时间撤销 在Android 4.1发布的时候包含了一种新的测试工具–uiautomator,uiautoma ...