Immudellazzjoni tajba tal-klassijski tfisser klassijiet li jimappaw għal kunċetti dominji reali, kull waħda b'responsabbiltà waħda ċara, relatati permezz ta' relazzjonijiet is-a/has-a onesti, u jiddependu fuq astrazzjonijiet fil-limiti. M'hemm l-ebda formula, iżda hemm proċess li jista' jiġi ripetut.
Proċess prattiku
1. Find the NOUNS → candidate classes (Order, Customer, Payment)
2. Find the VERBS → candidate behaviors/methods (place, refund, ship)
3. Assign each behavior to the class that OWNS the data it needs (high cohesion)
4. Choose relationships: IS-A (rare, must pass LSP) vs HAS-A (default)
5. Depend on interfaces at boundaries (DIP); inject volatile dependencies
6. Keep invariants inside the object (encapsulation); prefer immutability for values
