0

怎么能做到这一点?我需要继承,因为会有很多子类(它们在“打印机”函数中会有所不同),但是“creator_function”对于所有这些类都是相同的,并且子函数继承的特性比这个有问题的函数更多。

我不知道零件在??

  1. creator_function 的头部
  2. 调用传递函数
  3. 将函数传递给 creator_function
    class Base
    {
    public:
        void creator_function(vector< ?(int)functions_p(int)? > printers)
        {
           for(int i; i<printers.size(); i++)
           {
              ?int val = printers[i](10*i);?
              /* create some result here from val of all printers */
           }
        }
    };

    class Child : Base
    {
    public:
        int printer1(int x){ return x; }
        int printer2(int y){ return 2*y; }

        void create_result()
        {
            ? creator_function( {printer1, printer2} ); ?
        }
    };

Child c;
c->create_result();

我迷失在指向继承的成员函数的指针中。

打印机 1 和打印机 2 “不能”在 Base 中声明,因为子类中有很多不同的打印机(返回类型和参数相同),但每个子类中有不同数量的打印机和不同的名称

4

1 回答 1

0

尝试从基类调用子类的方法会变得一团糟。请记住,指向成员函数的指针只能通过该类的实例(“this”)调用。

经典的解决方案是有一个单独的打印机基类,上面有一个虚拟print方法。然后有一printer1printer2派生类。那是更多的打字。

这是 lambda 非常有效的可靠案例。

通过对您的代码进行一些小的调整,它变得非常容易。请注意,我们现在传递给向量creator_functionconst引用。这使我们能够将 lambda 直接内联到 Child 类的函数调用中。

#include <iostream>
#include <vector>
#include <functional>

using namespace std;

class Base
{
public:

    typedef std::function<int(int)> pfunc;

    void creator_function(const std::vector<pfunc>& printers)
    {
        for (size_t i=0; i < printers.size(); i++)
        {
            int val = printers[i](10 * i);
        }
    }
};

class Child : Base
{
public:
    int printer1(int x) { return x; }
    int printer2(int y) { return 2 * y; }

    void create_result()
    {
        creator_function({
                             [this](int x) {return printer1(x); },
                             [this](int y) {return printer2(y); }
                         });
    }
};

int main()
{
    Child c;
    c.create_result();
}
于 2021-03-27T19:19:31.623 回答