と の次のラッパーを作成std::bind
しましたstd::queue
。
#include "Queue.h"
template<class T>
Queue<T>::Queue(T* input)
{
instance = input;
}
template<class T> template<typename... Args>
int Queue<T>::push(int (T::*func)(Args... args), Args... args)
{
queue.push(std::bind(func, instance, args...));
return queue.size();
}
template<class T>
int Queue<T>::pop()
{
if(!queue.empty())
{
queue.front()();
queue.pop();
return queue.size();
}
return 0;
}
template<class T>
bool Queue<T>::empty()
{
return queue.empty();
}
template<class T>
size_t Queue<T>::size()
{
return queue.size();
}
次のヘッダーを使用します。
#ifndef QUEUE_H_
#define QUEUE_H_
#include <functional>
#include <queue>
template <class T>
class Queue
{
private:
std::queue<std::function<void()>> queue; /**< the messaging queue, appended to using enqueue(), popped from using dequeue() */
T* instance;
public:
Queue(T*);
template<typename... Args>
int enqueue(int (T::*f)(Args... args), Args... args);
int dequeue();
bool empty();
size_t size();
};
#endif
バインドされた関数式をキューに追加し、後でそれらをポップできます ( queue->push<int>(&Object::jumpAround, 10);
and queue->pop()
)。<class T>
問題は、テンプレートなしでこれを実装できる汎用オブジェクトおよび関数ポインターが見つからなかったことです。
ここではテンプレートを使用するのがおそらく最も安全で最善の方法であることはわかっていますが、このキューを実装するコードの設計により、これを取り除く必要があります。何か案は?
std::bind
の最初のパラメーターは任意の関数にすることができ、2 番目のパラメーターは任意のオブジェクトにすることができるため、何らかの形で可能であるに違いないと思います。