Как передать изменяющуюся функцию-член через другую функцию?

Я пытаюсь передать функцию (f1) через другую функцию (f2), при этом не нужно указывать f1.

Пример кода

Class C {
    private: std::deque<T*> queue;
    public: edit_queue(std::function<void(T*)> f1, void* input);
};

C::edit_queue(...){
    queue.f1(input);
}

Однако это не компилируется с ошибкой:

no member named 'f1' in 'std::__1::deque<T *, std::__1::allocator<T *> >

Я хотел бы иметь возможность сделать оба:

edit_queue(push_back, T* input);     (1)

а также

edit_queue(push_front, T* input);    (2)

Я также попытался передать указатель на функцию:

public: edit_queue(void (*f1)(T*), T* input);
c::edit_queue(...){queue.f1(input);};

а также

private: std::deque<T*>* queue;
...

но получил тот же результат.

Кроме того, возможно ли также не указывать входы f1? Например, (1) и (2) будут работать так же, как:

edit_queue(pop_back);

1 ответ

Решение

f1 это не метод queue поэтому ваш код не скомпилируется. Вы можете иметь разную обработку edit_queue передавая лямбду и вызывая ее:

template <typename Container, typename T>
void edit_queue(std::function<void(Container&, const T&)> func, const T& data)
{
  func(queue, data);
}

Затем позвоните с лямбда, которая вызывает push_back или же push_front,

Другие вопросы по тегам