CursosWorkshop IAEmpresasPreciosBlogConfAiBotInicia sesiónSuscríbete
  • Cursos
  • Workshop IA
  • Empresas
  • Precios
  • Blog
  • ConfAiBot
Suscríbete
  • Cursos
  • Empresas
  • Comunidades
  • Blog
  • Tarjeta regalo
  • Soporte
  • Tienda
  • ConfAiBot
  • Contacta
  • Aviso legal
  • Condiciones generales
  • Política de privacidad
  • Política de cookies

Por qué NO usar getters y setters | Tell don't ask

1 de octubre de 2015 | screencasts

¿Usas getters y setters? ¿Te suenan los modelos de dominio anémicos? ¿El principio Tell don't ask? ¡En este vídeo aprenderemos más acerca de estos conceptos! Ya hemos trabajado un poco la parte de la capa de aplicación mediante el screencast sobre el principio de responsabilidad única, y la relación con la capa de infraestructura mediante el screencast sobre el principio de inversión de dependencias. En este vídeo nos centraremos en la capa de nuestro dominio, concretamente, los modelos de dominio.

Índice del vídeo

  • 0:19 Pregunta: En PHP se accede a atributos de clase públicos, ¿uso getters y setters?
  • 1:17 Principio de programación aplicable a todo lenguaje
  • 2:00 Modelo User con atributos de clase públicos
  • 3:19 Diferencia entre Data Transfer Object (DTO) y modelo de dominio. Qué es un modelo de domino anémico
  • 4:14 Qué problemas tiene usar atributos de clase públicos
  • 4:50 Modelo User como array asociativo/hashmap
  • 6:00 Qué problemas tiene usar arrays asociativos para el modelado de dominio
  • 6:50 Modelo User con atributos de clase privados, getters y setters (modelo anémico)
  • 7:17 Beneficios de usar getters y setters
  • 8:00 Por qué NO usar getters y setters
  • 9:12 Modelo de dominio User con comportamiento
  • 10:47 Qué beneficios tiene usar modelos de dominio ricos (con comportamiento)
  • 13:09 Conclusión: Ni atributos de clase públicos, ni getters y setters. Lo ideal: Lógica de negocio donde corresponda (alta cohesión)

Vídeo

Material relacionado

  • Tell don't ask: Artículo de Martin Fowler acerca del principio Tell don't ask
  • Tell, Don't Ask (thoughtbot): Ejemplos de violaciones del principio Tell don't ask en Ruby
  • Data Transfer Object: Artículo de Martin Fowler sobre el patrón de diseño DTO
  • Anemic Domain Model: Artículo también de Martin Fowler acerca del anti-patrón de modelos de dominio anémicos

Tags

Nivel MedioPHPRefactoringTell don't ask
AnteriorSoftware Craftsmanship Barcelona 2015
SiguienteEntrevista a Pablo Ros | Programador web en Softonic y Uvinum

Paga según tus necesidades

lite (sólo mensual)

19 €
al mes
  • Acceso a un subconjunto de cursos para sentar las bases para un código mantenible, escalable y testable
  • Factura de empresa
Popular

standard

24,92 €
Ahorra 121 €
Pago anual de 299 €
al mes
  • Catálogo completo de cursos
  • Recibir ofertas de empleo verificadas por Codely
  • Factura de empresa

premium

41,58 €
Ahorra 89 €
Pago anual de 499 €
al mes
  • Todos los beneficios anteriores
  • Acceso anticipado a nuevos cursos
  • Descuento en workshops

No subiremos el precio mientras mantengas tu suscripción activa