Evolucion del software

carlosradamesb 3,055 views 29 slides Oct 24, 2012
Slide 1
Slide 1 of 29
Slide 1
1
Slide 2
2
Slide 3
3
Slide 4
4
Slide 5
5
Slide 6
6
Slide 7
7
Slide 8
8
Slide 9
9
Slide 10
10
Slide 11
11
Slide 12
12
Slide 13
13
Slide 14
14
Slide 15
15
Slide 16
16
Slide 17
17
Slide 18
18
Slide 19
19
Slide 20
20
Slide 21
21
Slide 22
22
Slide 23
23
Slide 24
24
Slide 25
25
Slide 26
26
Slide 27
27
Slide 28
28
Slide 29
29

About This Presentation

No description available for this slideshow.


Slide Content

EVOLUCIÓN DEL SOFTWARE

DINÁMICA DE EVOLUCIÓN DE LOS PROGRAMAS

LAS LEYES DE LEHMAN 1 Cambio continuado Un programa que se usa en un entorno real necesariamente debe cambiar o se volverá progresivamente menos útil en ese entorno.

2 Complejidad creciente A medida que un programa en evolución cambia, su estructura tiende a ser cada vez más compleja.

3 Evolución prolongada del programa Sugiere que los grandes sistemas tienen su propia dinámica que se establece en una etapa temprana en el proceso de desarrollo.

4 Estabilidad organizacional Sugiere que la mayoría de los proyectos de programación grandes trabajan en lo que se denomina un estado saturado .

5 Conservación de la familiaridad Durante el tiempo de vida de un sistema, el cambio incremental en cada entrega es aproximadamente constante.

6 Crecimiento continuado La funcionalidad ofrecida por los sistemas tiene que crecer continuamente para mantener la satisfacción de los usuarios.

7 Decremento de la calidad La calidad de los sistemas comenzara a disminuir a menos que dichos sistemas se adapten a los cambios en su entorno.

8 Realimentación del sistema Es necesaria para lograr una mejora significativa del producto.

MANTENIMIENTO DEL SOFTWARE Es el proceso general de cambiar un sistema después de que éste ha sido entregado.

TIPOS DE MANTENIMIENTO C orrectivo : Se utiliza generalmente para referirse al mantenimiento para reparación de defectos. Adaptativo : Significa adaptar el software a nuevos requerimientos . Perfectivo : Significa mantener la funcionalidad del sistema , pero mejorando su estructura y su rendimiento.

F actores que conducen a costes de mantenimiento más elevados: Estabilidad del equipo. Después de entregar un sistema, es normal que el equipo de desarrollo se disuelva y la gente trabaje en nuevos proyectos . Responsabilidad contractual. El contrato para mantener un sistema normalmente está separado del contrato para desarrollar el sistema.

Habilidades del personal. El personal de mantenimiento a menudo no tiene experiencia y no está familiarizado con el dominio de la aplicación . Edad y estructura del programa. A medida que pasa el tiempo, la estructura de los programas tiende a degradarse con los cambios.

PREDICCIÓN DEL MANTENIMIENTO Se debería intentar predecir qué cambios del sistema son probables y qué partes del sistema son probablemente las más difíciles de mantener.

PROCESOS DE EVOLUCIÓN T ipo de software a mantener Los procesos de desarrollo utilizados El personal implicado en el proceso

Requerimientos existentes que no han sido implementados en el sistema entregado. Peticiones para nuevos requerimientos y reparaciones de errores por parte de los stakeholders del sistema. Nuevas ideas y propuestas para mejoras en el software por parte del equipo de desarrollo del sistema. Propuestas de cambio:

PROCESO DE EVOLUCIÓN Los procesos de identificación de cambios y evolución del sistema son cíclicos y continúan durante toda la vida del sistema.

PROCESOS DE EVOLUCIÓN Incluyen las actividades fundamentales de análisis de cambios, planificación de entregas, implementación del sistema y entrega de un sistema a los clientes.

IMPLEMENTACIÓN DE LOS CAMBIOS Si ocurre un defecto serio en el sistema que tenga que ser reparado para permitir la continuación del funcionamiento normal . Si los cambios en el entorno del sistema operativo tienen efectos inesperados que impiden el funcionamiento normal . Si hay cambios no anticipados en las empresas que utilizan el sistema .

REINGENIERÍA DE SISTEMAS La reingeniería del software se refiere a la reimplementación de los sistemas heredados para hacerlos más mantenibles.

REINGENIERÍA DE SISTEMAS Redocumentar el sistema. Organizar y reestructurar el sistema. Traducir el sistema a un lenguaje de programación más moderno. Modificar y actualizar la estructura y valores de los datos del sistema. Puede implicar:

REINGENIERÍA DE SISTEMAS Ventajas: Riesgo reducido. Existe un alto riesgo en volver a desarrollar software crítico para los negocios. Coste reducido. El coste de hacer reingeniería es significativamente menor que el coste de desarrollar nuevo software.

REINGENIERÍA DE SISTEMAS Desventajas: E xisten límites prácticos a la extensión del sistema que puede ser mejorada mediante reingeniería . No es posible convertir un sistema diseñado utilizando una aproximación funcional en un sistema orientado a objetos. Los cambios arquitectónicos mayores no pueden realizarse de forma automática, implica costes adicionales.

REINGENIERÍA DE SISTEMAS La distinción crítica entre reingeniería y nuevo desarrollo software es el punto de partida del desarrollo.

EVOLUCIÓN DE SISTEMAS HEREDADOS

1.Desechar completamente el sistema . Esta opción debería elegirse cuando el sistema no constituye una contribución efectiva para los procesos de negocio. 2.Dejar el sistema sin cambios y continuar con un mantenimiento regular . Esta opción debería elegirse cuando el sistema todavía es necesario. Opciones estratégicas:

3.Hacer reingeniería del sistema para mejorar su mantenibilidad. Esta opción debería elegirse cuando la calidad del sistema se ha degradado por los cambios continuos . 4.Reemplazar todo o parte del sistema con un nuevo sistema. Esta opción debería elegirse cuando otros factores, como un nuevo hardware, implican que el sistema antiguo no puede continuar en funcionamiento.

EVOLUCIÓN DEL SOFTWARE Espacio para: preguntas, dudas, aclarando, aportaciones y plugins
Tags