PHP 8.4 simplifie radicalement l'écriture de classes propres en PHP grâce à des fonctionnalités comme la promotion des propriétés dans le constructeur, les propriétés readonly et la visibilité asymétrique. L'auteur illustre cette évolution avec un exemple concret : une classe ControllerActor passe de 12 lignes (avec propriétés privées, constructeur et getters) à seulement 4 lignes en utilisant ces nouvelles syntaxes, tout en garantissant l'immutabilité des données. Cette approche réduit la verbosité du code et améliore sa sécurité en empêchant les modifications accidentelles.
L'immutabilité des objets, rendue plus accessible par PHP 8.4, offre des avantages majeurs comme la sécurité des threads, l'absence d'effets de bord et une meilleure maintenabilité. Cependant, l'auteur souligne que cette pratique n'est pas universelle : les entités avec un cycle de vie (comme les utilisateurs ou les demandes de dépôt) doivent rester mutables pour des raisons de performance et de cohérence. Les collections dynamiques ou les objets hydratés par des ORM comme Doctrine nécessitent également une approche différente.
Enfin, l'article met en garde contre les pièges courants, notamment avec des outils comme Symfony Forms ou EasyAdmin, qui peuvent ne pas être compatibles avec ces nouvelles fonctionnalités. En adoptant l'immutabilité de manière ciblée (pour les objets de valeur ou les événements), les développeurs gagnent en fiabilité et en clarté, tout en évitant les régressions liées aux modifications implicites de données.
Cet article de Sebastian Bergmann explique les différences entre les Data Transfer Objects (DTOs) et les Value Objects, et pourquoi l'immutabilité facilite les tests. Les DTOs, motivés techniquement, servent à transférer des données entre couches ou systèmes, tandis que les Value Objects, motivés par le domaine, représentent des concepts stables du domaine. L'immutabilité réduit la charge cognitive en test, car elle garantit que l'état des objets ne change pas. Les Value Objects, étant immuables, n'ont pas besoin de test doubles, contrairement aux DTOs qui peuvent en nécessiter si ils contiennent de la logique. L'utilisation d'objets immuables simplifie les tests en évitant les effets de bord indirects.
L'article explique pourquoi privilégier l’immuabilité en programmation orientée objet permet d’éviter des bugs subtils liés à l’état partagé. L’auteur illustre le problème avec un exemple en PHP où la mutation d’un objet DateTime affecte involontairement une autre partie du code, rendant le débogage difficile. Les objets immuables (comme DateTimeImmutable) évitent ce genre de piège en retournant une nouvelle instance à chaque modification, plutôt que de modifier l’original. Les avantages incluent une meilleure prévisibilité du code, une réduction des effets de bord et une gestion plus sûre de la concurrence. Cependant, l’immuabilité peut introduire un surcoût en performance et n’est pas toujours adaptée (ex. : objets builders éphémères). L’article conclut en encourageant à adopter l’immuabilité par défaut, sauf besoin contraire, pour un code plus robuste et maintenable.
Tout est dans le titre
Tout est dans le titre
Tout est dans le titre