<h3>Rule 3: Make meaningful distinctions</h3> <div class="bad"> <code>getUserInfo()</code> and <code>getUserData()</code> — what’s the difference? </div> <div class="good"> <code>getUserProfile()</code> vs <code>getUserCredentials()</code> </div>
<ul> <li><strong>Rigidity</strong>: A small change breaks many parts → increase cohesion, reduce coupling.</li> <li><strong>Fragility</strong>: Changes cause unexpected failures → add tests, encapsulation.</li> <li><strong>Opacity</strong>: Code is hard to understand → rename, refactor, add explanatory variables.</li> <li><strong>Feature envy</strong>: A method seems more interested in another class’s data → move the method.</li> <li><strong>Long parameter list</strong>: Wrap parameters into an object (DTO).</li> </ul> codigo limpo epub
<h3>No side effects</h3> <p>A function named <code>checkPassword()</code> should not also initialize a session. Do one thing.</p> Rule 3: Make meaningful distinctions<