栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Java Are getters and setters poor design?自相矛盾

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java Are getters and setters poor design?自相矛盾

还有一种观点认为,在大多数情况下,使用setter仍会通过允许你设置无意义的值来破坏封装。举一个非常明显的例子,如果你在游戏中拥有一个只会不断提高的得分计数器,而不是

// Gameprivate int score;public void setScore(int score) { this.score = score; }public int getScore() { return score; }// Usagegame.setScore(game.getScore() + ENEMY_DESTROYED_SCORE);

它应该是

// Gameprivate int score;public int getScore() { return score; }public void addScore(int delta) { score += delta; }// Usagegame.addScore(ENEMY_DESTROYED_SCORE);

这也许是一个简单的例子。我要说的是,讨论吸气剂/吸气剂与公共场所之间的关系通常会掩盖更大的问题,因为对象以一种亲密的方式操纵彼此的内部状态,因此过于紧密。

这个想法是使方法可以直接做你想做的事情。一个例子就是如何设置敌人的“存活”状态。你可能会想拥有一个setAlive(boolean alive)方法。相反,你应该具有:

private boolean alive = true;public boolean isAlive() { return alive; }public void kill() { alive = false; }

这样做的原因是,如果更改实现,使事物不再具有“有效”布尔值,而是“命中点”值,则可以在不破坏你先前编写的两种方法的约定的情况下进行更改:

private int hp; // Set in constructor.public boolean isAlive() { return hp > 0; } // Same method signature.public void kill() { hp = 0; } // Same method signature.public void damage(int damage) { hp -= damage; }


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/393804.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号