使用适配器设计模式

Using Adapter Design Pattern

本文关键字:设计模式 适配器      更新时间:2023-10-16

我正在实现一个适配器设计模式,以利用现有的类。我的问题是,这些类的工作原理几乎相同,但名称不同,在另一个类上的功能更少。

例如,Work类和Homework每个类都有一个执行相同操作的函数,即doWork()doHomework()
我可以将这些链接到Task界面中的doThis()。但是,Work类没有done()函数,而Homework有它。我该如何处理这个问题?只是没有实现?有什么更好的方法吗?

class Task {
public:
  virtual int doThis() = 0;
  virtual bool done() = 0;
};
class Work {
public:
  Work();
  int doWork();
};
class Homework {
public:
  Homework();
  int doHomework();
  bool done();
  bool isDone;
};
class WorkAdapter : public Task, private Work {
public:
  WorkAdapter();
  int doThis() {
    return doWork();
  }
  virtual bool done() {
    // Is this okay not to implment this?
  }
};
class HomeworkAdapter : public Task, private Homework {
public:
  HomeworkAdapter();
  int doThis() {
    return doWork();
  }
  virtual bool done() {
    return isDone;
  }
};
int main() {
  Task *homework = new HomeworkAdapter();
  Task *work = new WorkAdapter();
  homework->doThis();
  bool isHomeworkDone = homework->done();
  work->doThis();
  bool isWorkDone = work->done();  // This would never be called in my implementation...
}

使用多重继承的适配器实现(目标为public,适配器为private)是一种有效的方法。

只需注意函数的返回类型:

class HomeworkAdapter : public Task, private Homework {
public:
  HomeworkAdapter() {}
  int doThis() override {  // make sure you override target member
    return doWork();       // and return value as expected
  }
  bool done() override {
    return isDone;
  }
};

提示:不需要在派生类中指定virtual。相反,使用重写是值得的,只是为了避免在参数或返回类型不匹配的情况下出现微妙的问题

当适配器中没有可用于处理done()的功能时,您必须模仿它。因此,这不仅仅是为了更改名称,还需要确保类似的行为:

class WorkAdapter : public Task, private Work {
  bool isdone;       // functionality to add
public:
  WorkAdapter() : isdone(false) {}
  int doThis() override {
    auto rc = doWork();
    isdone = true;    // once it's done, it's done ;-)
    return rc; 
  }
  bool done() override {
    return isdone;      // you must add this 
  }
};