设为首页 收藏本站
查看: 1373|回复: 0

[经验分享] 面向对象程序设计之开放-封闭原则(OCP)

[复制链接]

尚未签到

发表于 2015-11-8 14:51:43 | 显示全部楼层 |阅读模式
  所谓开放就是一个模块的功能是可以扩展的,是可以随时满足外部需求的变化;所谓封闭就是在模块功能扩展的同时,我们不必去改动原有模块的代码,不必去破坏原有模块的完整性,我们所要做的只是在模块之外添加一些代码。
  要满足这个原则的关键方法就是抽象,将模块的功能抽象化,例如我们现在需要开发一个模块去读入外部设备输入的数据并把数据显示出来,刚开始的时候,需求只是要求从键盘读入,于是我们实现我们的模块
  void module()
{
int data = ReadFromKB();//从键盘读入
ShowData(data);//显示数据
}



可是过了几天,需求变了,说是要求模块也可以从其他非键盘读入数据,好吧,只能改动module模块了,  
  



void module(int flag)
{
int data = flag? ReadFromKB() : ReadFromOther();//读入数据
ShowData(data);//显示数据
}
  

好吧,模块的接口居然发生了变化,模块的内部也被改动了,虽然对你来说很容易,但是你有没有发现,整个项目还有很多其他地方都用到了module模块,你这样轻松的将module的接口一改,其他用到了module的地方可就不能工作了,于是你发现整个程序都得改动,真可谓是牵一发而动全身。
至此我们发现引起module发生变动的原因是读数据的方式这个行为,所以我们想能不能将读数据这个行为给抽象化,使其与模块接口无关。这样无论我读数据的方式怎么变,从哪儿读入,module模块可以不用丝毫的改动。
这个时候充分运用c++的特性了,虚函数,抽象类。我们定义一个读数据的抽象类:
class Reader
{
public:
virtual int read() = 0;//纯虚函数,Reader为抽象类,不能实例化
};



重写module模块
void module(Reader &rd)
{
int data =  rd.read();//从键盘读入数据
ShowData(data);//显示数据
}



模块的参数为抽象类Reader的一个引用,也可以是指针,但是不能是实例.
好了,现在我们想从键盘读入数据了,可以这样写
class ReadKB : public Reader
{
public:
virtual int read()
{
return 11;//这里插入从键盘读书数据的代码
}
}

为了让模块工作,实例化一个ReadKB对象
ReadKB rdkb;
Reader &r = rdkb;
module(r);//模块开始工作了从键盘读书数据
那我要从其他地方读入数据怎么办,再次重写基类Reader的read函数
class Readother : public Reader
{
public:
virtual int read()
{
return 22;//这里插入从其他设备读书数据的代码
}
}



为了让模块工作,实例化一个Readother对象
Readother  rdot;
Reader &r = rdot;
module(r);//模块开始工作了从其他设备读书数据
总之,经过这样的抽象化,无论从设备读书数据,整个模块的接口及其内部是不发生变化的,这就是封闭,我们只需要增加一些代码便可以满足需求的变化,这就是开放。
从上面的一个例子我们可以看出,遵循OCP原则,也就是要求我们将那些容易引起模块发生变化的行为抽象化,所以在软件开发初始,我们要有预见性的预测哪些行为将会是有变化的。


参考资料<<敏姐软件开发:原则、模式与实践>>



  

版权声明:本文为博主原创文章,未经博主允许不得转载。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-136668-1-1.html 上篇帖子: OCP-1Z0-051 第92题 日期格式 下篇帖子: Oracle OCP笔记(20)数据库安全与审计
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表