God klassmodellering betyder klasser som mappas till verkliga domänkoncept, var och en med ett tydligt ansvar, relaterade genom ärliga is-a/has-a relationer, och beroende på abstraktioner vid gränserna. Det finns ingen formel, men det finns en repeterbar process.
En praktisk process
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
