《你必须知道的.NET》读书笔记二:小OO有大原则
此篇已收录至《你必须知道的.Net》读书笔记目录贴,点击访问该目录可以获取更多内容。
一、单一职责原则
(1)核心思想:一个类最好只做一件事,只有一个引起它变化的原因
(2)常用模式:Facade模式、Proxy模式
(3)基本方法:Extract Interface 抽取接口、Extract Class 抽取类、Extract Method 抽取方法
(4)DEMO:数据库管理系统中根据不同权限进行CRUD操作(这里是使用Proxy模式重构后的代码)
(5)规则建议:
①一个类只有一个引起它变化的原因,否则就应当考虑重构;
②测试驱动开发,有助于实现合理分离功能的设计;
③可以通过Facade模式或Proxy模式进行职责分离;
二、开放封闭原则
(1)核心思想:软件实体应该是可扩展的,而不可修改的-->即对扩展开放,对修改封闭。在面向对象的编程中,即对抽象编程,而不对具体编程。
(2)常用模式:Template Method模式、Strategy模式
(3)DEMO:银行窗口业务办理场景
(4)规则建议:
①Liskov替换原则和合成/聚合复用原则为OCP实现提供保证;
②可以通过Template Method和Strategy模式进行重构;
③封装变化是实现OCP的重要手段;
三、依赖倒置原则
(1)核心思想:依赖于抽象-->抽象不应该依赖于具体,具体应该依赖于抽象;
(2)基本方法:在依赖之间定义一个抽象的接口,高层模块调用接口的方法,低层模块实现接口的定义;
(3)DEMO:银行窗口不同业务客户场景
(4)规则建议:
①必须权衡在抽象和具体之间的取舍,方法不是一成不变的;
②依赖于抽象就是要对接口编程,不要对实现编程;
四、接口隔离原则
(1)核心思想:使用多个小的专门的接口,而不使用一个大的总接口;接口应该是内聚的,应该避免出现“胖”接口;不要强迫依赖不用的方法,这是一种接口污染;
(2)基本方法:委托分离与多重继承分离(推荐)
(3)DEMO:不同年龄段人士使用电脑场景
(4)规则建议:
①将功能相近的接口合并,可能造成接口污染;
②接口隔离能够保证系统扩展和修改的影响不会扩展到系统其他部分;
五、Liskov替换原则
(1)核心思想:子类必须能够替换其基类
(2)DEMO:父类提供虚函数,子类覆写虚函数
(3)规则建议:
①违反了Liskov替换原则必然导致违反开放封闭原则;
②Liskov替换能够保证系统具有良好的扩展性;
③子类的异常必须控制在父类可以预计的范围,否则将导致替换违规;
本章思维导图