We should encourage immutability because it makes the code more predictable and straightforward. So we can be sure that our data are truths.
Basically it comes down to the fact that immutability increases predictability, performance (indirectly) and allows for mutation tracking.
Mutation hides change, which create (unexpected) side effects, which can cause nasty bugs. When you enforce immutability you can keep your application architecture and mental model simple, which makes it easier to reason about your application.
Even though adding values to an immutable Object means that a new instance needs to be created where existing values need to be copied and new values need to be added to the new Object which cost memory, immutable Objects can make use of structural sharing to reduce memory overhead.
Besides reduced memory usage, immutability allows you to optimize your application by making use of reference- and value equality. This makes it really easy to see if anything has changed.
// Bad $dateTime = new DateTime('09-10-2019'); $dateTime->modify('+1 day'); // The original object changed $dateTime->format('Y-m-d'); // 2019-10-10
// Good $dateTime = new DateTimeImmutable('09-10-2019'); $modified = $dateTime->modify('+1 day'); // The original object remains the same $dateTime->format('Y-m-d'); // 2019-10-09 // `modify()` returns a new object instead $modified->format('Y-m-d'); // 2019-10-10