微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SOLID原则之依赖倒转

面向对象编程的一个重大功能就是“继承”,它可以使用现有类的所有功能,并在无需重新编写原来的类的情况下对这些功能进行扩展。

从“继承”的特点来看,继承的作用之一,就是可以使派生类无差别的使用基类的方法,以实现逻辑的重用。

但从虚函数,尤其是纯虚函数来看,“继承”的作用更多的在于“逻辑的分层”,以实现模块间的松耦合。

举个例子,如:

class Logger

{

public:

virtualvoid LOG(char * info) = 0;


}


void func(Logger logger)

{

// do something

logger.LOG("func exit.");

}


对于classLogger而言,其有一个纯虚函数LOG(我们将其定义为记录日志的功能逻辑),另外一个函数func在退出调用了LOG方法,记录函数退出

为什么会这样去实现?

在实际的项目中,代码架构往往分不同的模块/层次,对于基于Base开发的模块/系统,可能有不同的日志格式诉求。

按照传统的思想,如果基于Logger的系统有不同的诉求,那么就提供不同的LOG方法不就行了?

这样的想法,往往是灾难性的。实际运作过程中的极端情况下,Logger类的系统往往在一个团队中维护,而基于Logger开发的系统可能在另一个团队、甚至另外的企业。如果按照传统的思想,两个团队之间的“耦合”就产生了。

这个时候,“继承”就派上用场了,基于Logger开发的系统,完全可以重写自己的日志函数


class NewLogger : public Logger

{

public:

void LOG(char * info)

{

// ...

}

}


调用func函数时,只需要如下调用即可:

NewLogger newLogger;

func(newLogger);


“分层”的思想作为计算机体系中解决问题的一种最常用思路,OOP中的继承从一定程度上讲正是迎合该思想而产生的,而SOLID原则中的“依赖倒转原则”正是通过“继承”来支撑的。

原文地址:https://www.jb51.cc/javaschema/286309.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐