Alta cohesión

Bajo acoplamiento


Manuel G. Ochoa
Cindy Vanessa Perez
Camilo A. Sampedro

Grado de Cohesión

El nivel en el que el contenido de la clase es coherente con respecto a las responsabilidades de esta.

¿Está bien enfocada la clase a su propósito?

Grado de acoplamiento

Nivel de dependencia de una clase con respecto a otras.
¿Qué tan susceptible es la clase a cambios hechos en otras clases?

Tipos de cohesión:

  • Cohesión coincidente.
  • Cohesión lógica.
  • Cohesión temporal.
  • Cohesión de procedimiento.
  • Cohesión de comunicación.
  • Cohesión de información.
  • Cohesión funcional.

Cohesión coincidente:

Sus tareas no tienen ningún tipo de relación entre sí.

Cohesión lógica:

Las tareas entran en una misma categoría, pero no se relacionan unas con otras.


Cohesión temporal:

Las tareas se relacionan al tener que ser ejecutadas al mismo tiempo.

Cohesión de procedimiento

Las tareas corresponden a una misma secuencia de acciones propia de la clase.

Cohesión de comportamiento

Las tareas tienen cohesión de procedimiento y además afectan a los mismos datos.


Cohesión de información

Las tareas tienen su propio punto de arranque, codificación independiente y trabajan sobre los mismos datos (ej: objetos)


Cohesión funcional

Se ejecutan llegando a un solo fin.

Tipos de acoplamiento

  • De contenido: Un módulo referencia directamente el contenido de otro.
  • Común: Dos o más módulos acceden y afectan a un mismo valor global.
  • De control: Un módulo envía a otro un elemento de control que determina la lógica de ejecución del mismo.

¿Para qué sirve?

Hace los módulos más fáciles de modificar posteriormente.

Permite a los módulos encargarse únicamente de sus responsabilidades, haciéndolas más sencillas.


Ejemplo alto acoplamiento.

class ProcesosImpuestos {
    float estimacion;
    float hacerEstimacion() {
        ValoresTasas vals = new ValoresTasas();
        estimacion = vals.estimacionVentas;//Debería haber sido llamado como un método. Por ejemplo obtenerEstimacionVentas("CO").
    }
}
class ValoresTasas {
    public float estimacionVentas;//Debería ser private.
    public float estimacionVentasAjustado;//Debería ser private.
    public float obtenerEstimacionVentas(String region) {
        estimacionVentas = new ProcesosImpuestos().hacerEstimacion(); //Se debería de hacer el cálculo directamente aquí.
        return estimacionVentasAjustado;
    }
}

Ejemplo baja cohesión

class InformePresupuesto {
    void conectarABaseDeDatos(){ }
    void generarInformeDePresupuesto() { }
    void guardarAArchivo() { }
    void mostrar() { }
}
class InformePresupuesto {
    Opciones obtenerOpcionesDeReporte() { }
    void generarInformeDePresupuesto(Opciones o) { }
}
 
class ConexionABaseDeDatos {
    ConexionDB obtenerRDBMS() { }
}
 
class MaterialImpresion {
    OpcionesImpresion obtenerOpcionesImpresion() { }
}
 
class ManejadorArchivo {
    OpcionesGuardado obtenerOpcionesDeGuardadoAArchivo() { }
}

Fuentes:

  • http://juan-garcia-carmona.blogspot.com/2012/09/grasp-a
    lta-cohesion-y-bajo-acoplamiento.html
  • http://kimeraweb.com.es/SCJP/tema17.php
  • http://cysingsoft.wordpress.com/2009/06/23/modularida
    d-cohesion-y-acoplamiento-carlos-fontela/
  • http://es.wikipedia.org/wiki/Dise%C3%B1o_estructurado
  • http://es.wikipedia.org/wiki/GRASP#Alta_cohesi.C3.B3n_y
    _bajo_acoplamiento
Made with Slides.com