Premium Partner

ESE Intro

jjnkl

jjnkl


Kartei Details

Karten 37
Sprache English
Kategorie Informatik
Stufe Universität
Erstellt / Aktualisiert 17.12.2019 / 19.12.2019
Lizenzierung Keine Angabe
Weblink
https://card2brain.ch/box/20191217_ese
Einbinden
<iframe src="https://card2brain.ch/box/20191217_ese/embed" width="780" height="150" scrolling="no" frameborder="0"></iframe>

Why Software Engineering?

—Where did the specification come from?

—How do you know the specification corresponds to the user’s needs?

—How did you decide how to structure your program?
—How do you know the program actually
meets the specification? —How do you know your program will always work correctly? —What do you do if the users’ needs change?

—How do you divide tasks up if you have more than a one-person team?

What is Software Engineering?

State of the art of developing quality software on time and within budget

Multi person construction of multi version software

Software engineering is different from other engineering disciplines (not constrained by physical law)

(Engineering practices cover not only technological aspects of the products being built, but also such diverse aspects such as planning, process management, and quality standards.

Software development activities

Requirements Collection: Establish customer's needs

Analysis: Model annd specify the requirements ('what')

Design: Model and specify a solution ('how')

Implementation: Construct a solution in a software

Testing: Validate the solution against the requirements

Maintenance: Repair defects and adapt the solution to new requirements

(these are ongoing activties not sequential phases)

Why is the waterfall model unrealistic? What are the problems?

- Because requirements must be frozen too early in the life cycle

- Because requirements are validated too late

--------------------------------

  1. Iteration always occurs
  2. Difficult to state all requirements explicitly at the beginning of the project
  3. There won't be a working version of the software until late in the project

(Early prototyping helps to alleviate 2 and 3)

Why Iterative Development?

New requirements can be introduced at any point in the project. Implementation of prototypes may start before detailed design to explore requirements. Testing typically starts as implementation starts.

Plan to iterate your analysis, design and implementation

(You won't get it right the first time, so integrate, validate, test)

(You should only use iterative development on projects that you want to succeed)

Boehm's Spiral Lifecycle

With each iteration the system incrementally grows and evolves

Keyword: Iterative and incremental spiral lifecycle

Incremental Development

If possible always have a running version of the system, even if most functionality is yet to be implemented

Integrate new functionality as soon as possible

Validate incremental versions against user requirements

The Rational Unified Process

Framework for an iterative development lifecycle proposed by Rational Software.