官术网_书友最值得收藏!

The observer pattern

As we advance in this book, we keep mentioning how important decoupling is. When we reduce dependencies, we can extend, develop, and test different modules without having to know the implementation details of other modules. All we have to know is the abstraction they implement.

However, modules should work together in practice. And it's not uncommon that changes in one object are known by another object. For example, if we implement a car class in a game, the engine of the car should know when the accelerator changes its position. The naive solution would be to have an engine class that checks from time to time the accelerator position to see whether it has changed. A smarter approach would be to make the accelerator call the engine to inform it about the changes. But this is not enough if we want to have well-designed code.

If the Accelerator class keeps a reference to the Engine class, what happens when we need to display on screen the position of Accelerator? This is the best solution: instead of making the accelerator dependent on the engine, we should make both of them rely on abstractions.

主站蜘蛛池模板: 西和县| 平果县| 横山县| 吉安县| 兴安盟| 三原县| 宜兴市| 荃湾区| 富阳市| 达尔| 额尔古纳市| 正定县| 南昌县| 榕江县| 江源县| 望都县| 崇阳县| 荣成市| 阿坝县| 通州区| 怀仁县| 高尔夫| 久治县| 前郭尔| 塘沽区| 台东市| 双江| 漾濞| 瓮安县| 韶关市| 乃东县| 双江| 清新县| 武宁县| 和政县| 衡山县| 原阳县| 呼伦贝尔市| 麻阳| 莆田市| 区。|