[PHP] El patrón de diseño (o antipatrón) singleton vs Inyección de dependencias ¿Que debo usar?

PHP es un lenguaje con el cual podemos usar herramientas avanzadas de desarrollo, algunas de estas herramientas son los patrones de diseño (Design Patterns),regularmente cuando empezamos a adentrarnos a esto de los patrones de diseño, uno de los primeros patrones que empezamos a usar es el patrón singleton, el cual garantiza un único acceso a cierto clase como una base de datos la implementación que yo uso/usaba es la siguiente:

En la primera clase tenemos la implementación del singleton, y en la segunda clase en el constructor estamos llamando al singleton, sin embargo, caemos en una mala practica, la cual si vemos Mysql::getInstance() es como si fuera una llamada a una clase estática global, la cual es como si estuviéramos usando variables globales, lo cual es totalmente desaconsejado de usar, como comentan en mundogeek por las siguientes cosas:

  • El código es más difícil de entender
  • El código es más difícil de depurar
  • El código es más difícil de testear
  • El código es más difícil de mantener
  • El código es más difícil de reutilizar
  • Las variables globales matan gatitos

Extraído de: http://mundogeek.net/archivos/2011/07/12/variables-globales/

Entonces vemos que a pesar que de es posible usar Singleton no deberíamos de usarlo, solo en casos muy excepcionales, aunque es mejor buscar algún otro patrón de diseño.

Lo que deberíamos usar el la inyección de dependencias, que si bien es fácil de usar puede ser un poco complejo de entender:

La inyección de dependencias soluciona todos los items anteriores, y nos da una accesibilidad concreta a cada clase que necesitemos, si pasamos el código anterior a inyección de dependencia seria de la siguiente forma:

Como vemos es simple de implementar pero debemos estudiar bien el código, para que con esto no solo evitemos el uso de Singletons (“globales glorificadas”), si no que además podamos usar TDD(Desarrollo Guiado por Pruebas) sin ninguna complicación, además de tener un código claro y fácil de reutilizar componentes.

Como en este caso, podemos tener varios manejadores de base de datos como Mysql, SqlServer, etc, y podemos definir claramente cual necesitamos.

Como nota aclaratoria, yo no condeno el uso de singletons pero su uso debe de ser muy excepcional, de hecho Kohana Framework los usa pero para casos muy concretos de hecho casi todo su código usa inyección de dependencias.

1 Comentario

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos necesarios están marcados *

*

Puedes usar las siguientes etiquetas y atributos HTML: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code class="" title="" data-url=""> <del datetime=""> <em> <i> <q cite=""> <strike> <strong> <pre class="" title="" data-url=""> <span class="" title="" data-url="">