Descargar

Programación Orientada a Aspectos – La verdad desnuda (página 2)

Enviado por Pablo Turmero


Partes: 1, 2, 3
edu.red POA La POA promueve la separación de conceptos a través de mecanismos, que permiten abstraer y componer estos conceptos a lo largo del sistema. Un aspecto es un concepto que no es posible encapsularlo claramente, y que resulta diseminado por todo el código. Un aspecto será la unidad que encapsulará un concepto entrecruzado.

edu.red Conceptos POA Aplicando POA se puede escribir una funcionalidad básica “pura”, y especificar cada aspecto por separado. Luego, existe un proceso de combinación que compondrá el sistema final.

Los puntos de enlace brindan la interfaz entre aspectos y componentes. Son lugares dentro del código donde es posible agregar comportamiento adicional.

El comportamiento adicional puede agregarse en tres momentos particulares: antes, después, en lugar de .

El encargado de la composición es llamado Weaver. Guiado por los puntos de enlace teje el código base con el código de los aspectos.

edu.red Estructura Estructura Tradicional

edu.red Estructura POA

edu.red Ejemplo 2: biblioteca Class Biblioteca { private libro [] libros ; private socio [] socios;   public Biblioteca() { …

public void prestamo( socio S, libro L) { if controlDeAccesoValido() then{ // código del método } else{ generarExcepcion(); } }

public void ingresarSocio(socio S){ if controlDeAccesoValido() then{ // código del método } else{ generarExcepcion(); } } // demás métodos… }

Control de acceso Funcionalidad básica

edu.red Definición de un aspecto Aspecto Control { Punto de enlace operacionesSeguras = llamadas a Biblioteca.prestamo & llamadas a Biblioteca.ingresarSocio& … antes de operacionesSeguras: { if !=(controlDeAccesoValido()) then{ generarExcepcion(); } }

edu.red Ejemplo TFTP Se implementó con AspectJ el protocolo de comunicación TFTP. Protocolo muy simple para transferir archivos entre procesos Reingeniería y Aspecto de Logging. Código de logging: 31%.

edu.red

edu.red Relación POA y POO (Gp:) Clase A (Gp:) Clase A1 (Gp:) Attb1 Attb2 (Gp:) Método 1 (Gp:) Clase A2 (Gp:) Attb 3 (Gp:) Método 1 Método 2

POO: conceptos comunes POA: conceptos entrecruzados

edu.red ¿De donde venimos? El grupo de PA en Boston, quería hacer código según la ley de demeter. Cristina Videira Lopes miembro Ph.D introduce “Separations of Concerns”. En 1995 Cristina se une en Xerox Park, con Gregor Kiczales. En noviembre nace la sigla AOP. En 1998 sale la 1º versión de AspectJ, implementado dos lenguajes de Cristina.

edu.red Historia en Imágenes

edu.red POA y los demás paradigmas Mayormente, se utiliza en relación a la POO. Sin embargo, existen aplicaciones de POA a otros paradigmas también.

Imperativo: Desarrollos y extensiones a C para implementación de SO. Lógicos: aspectos al estilo ?envio (X,Y). Estilo declarativo, consultas.

edu.red Herramientas OA Lenguajes para programar Aspectos: AspectJ: Extensión a Java para aplicar aspectos. La más popular. AspectC++,AspectS, CAESAR. En .NET: Weave.NET, Source Weave. SetPoint: Framework en .NET. Basado en la semántica y no en la sintaxis.

edu.red Todo el ciclo de desarrollo Si bien al principio todo era programar, los conceptos AOP se trasladaron a todo el proceso de Software.

? por lo tanto:

AORE: Aspect Oriented Requirement Engineering.

Arquitectura OA

AOD: Aspect Oriented Design. Extensiones a UML para soportar el manejo de aspectos en la etapa de diseño. Extensiones Generales y Específicas.

Verificación, Formalización &Model Checking OA

edu.red Diseño OA No se banca bien los aspectos. Se extiende UML para tal fin. Extensiones al metamodelo. Extensiones con mecanismos propios. OCL para restricciones: joinpoints.

edu.red Extensiones al metamodelo

edu.red Extensiones Específicas Se maneja con los mecanismos propios de extensión de UML: estereotipos, restricciones, y valores etiquetados. Ejemplo para aspecto de distribución

edu.red Conclusiones Contribuciones principales de: AORE Arquitectura OA Diseño OA

edu.red AORE = Trato para los req. funcionales y no. Reconocer que los req. se entrecruzan e influyen entre sí. Fundamental contar con sólidos mecanismos de composición

edu.red Arquitectura OA Pequeñísimas aproximaciones y Herramientas. El área más tímida de desarrollo hoy día. Mostró útil y viable un lenguaje de arquitectura OA. Creciente consenso en la comunidad para separar las ?vistas.

Partes: 1, 2, 3
 Página anterior Volver al principio del trabajoPágina siguiente