加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

SOLID原则之依赖倒转

发布时间:2020-12-13 19:55:35 所属栏目:百科 来源:网络整理
导读:面向对象编程的一个重大功能就是“继承”, 它可以使用现有类的所有功能,并在无需重新编写原来的类的情况下对这些功能进行扩展。 从“继承”的特点来看,继承的作用之一,就是可以使派生类无差别的使用基类的方法,以实现逻辑的重用。 但从虚函数,尤其是纯

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

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

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

举个例子,如:

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原则中的“依赖倒转原则”正是通过“继承”来支撑的。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读