std::vector из std::function
У меня есть следующее:
typedef std::function<void(const EventArgs&)> event_type;
class Event : boost::noncopyable
{
private:
typedef std::vector<event_type> EventVector;
typedef EventVector::const_iterator EventVector_cit;
EventVector m_Events;
public:
Event()
{
}; // eo ctor
Event(Event&& _rhs) : m_Events(std::move(_rhs.m_Events))
{
}; // eo mtor
// operators
Event& operator += (const event_type& _ev)
{
assert(std::find(m_Events.begin(), m_Events.end(), _ev) == m_Events.end());
m_Events.push_back(_ev);
return *this;
}; // eo +=
Event& operator -= (const event_type& _ev)
{
EventVector_cit cit(std::find(m_Events.begin(), m_Events.end(), _ev));
assert(cit != m_Events.end());
m_Events.erase(cit);
return *this;
}; // eo -=
}; // eo class Event
И во время компиляции:
1>c:\program files (x86)\microsoft visual studio 10.0\vc\include\algorithm(41): error C2451: conditional expression of type 'void' is illegal
1> Expressions of type void cannot be converted to other types
Теперь я понимаю, что это из-за того, что хранится в векторе и операторе ==
, Есть ли другой способ хранения std::function
в контейнере STL? Нужно ли оборачивать это чем-то другим?
1 ответ
Решение
Вы можете хранить boost::function
в векторе, если вы не используете std::find
, Поскольку вам, кажется, это нужно, лучше всего обернуть функцию в ее собственный класс равенством.
class EventFun
{
int id_;
boost::function<...> f_;
public:
...
bool operator==(const EventFun& o) const { return id_==o.id_; } // you get it...
};
Обратите внимание, что для этого необходимо поддерживать id_
в здравом смысле (например, два разных EventFun
с будут разные id_
с и т. д.).
Другая возможность будет хранить boost::function
s с тегом, который клиент запомнил бы и использовал для идентификации конкретной функции при его удалении.